| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195 |
- <template>
- <ele-modal
- custom-class="ele-dialog-form long-dialog-form"
- :centered="true"
- v-if="visible"
- :visible.sync="visible"
- :close-on-click-modal="false"
- :append-to-body="true"
- width="70%"
- @close="cancel"
- :maxable="true"
- :resizable="true"
- :title="title"
- >
- <el-form
- ref="form"
- :model="form"
- :rules="rules"
- label-width="120px"
- class="el-form-box"
- >
- <headerTitle title="订单信息"> </headerTitle>
- <el-row>
- <el-col :span="24">
- <el-form-item label="订单类型" prop="needProduce">
- <el-radio
- v-model="form.needProduce"
- :label="1"
- @change="needProduceChange"
- >有客户生产性订单</el-radio
- >
- <el-radio
- v-model="form.needProduce"
- :label="0"
- @change="needProduceChange"
- >库存式订单</el-radio
- >
- <el-radio
- v-model="form.needProduce"
- :label="2"
- @change="needProduceChange"
- >无客户生产性订单</el-radio
- >
- <el-radio
- v-model="form.needProduce"
- :label="5"
- @change="needProduceChange"
- >委外订单</el-radio
- >
- <el-radio
- v-model="form.needProduce"
- :label="4"
- @change="needProduceChange"
- v-if="clientEnvironmentId != 5"
- >不定向订单</el-radio
- >
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="8">
- <el-form-item label="销售类型" prop="saleType">
- <DictSelection
- dictName="销售类型"
- clearable
- v-model="form.saleType"
- :listFormatte="listFormatte"
- @change="saleTypeChange"
- >
- </DictSelection>
- </el-form-item>
- <el-form-item label="销售部门" prop="salesDeptId">
- <ele-tree-select
- clearable
- :data="groupTreeData"
- v-model="form.salesDeptId"
- valueKey="id"
- labelKey="name"
- placeholder="请选择"
- @change="change_principalDep"
- default-expand-all
- />
- </el-form-item>
- <el-form-item label="是否挂单" prop="isSuspend">
- <el-radio-group v-model="form.isSuspend">
- <el-radio :label="1">是</el-radio>
- <el-radio :label="0">否</el-radio>
- </el-radio-group>
- <span v-if="form.isSuspend == 1" style="margin-left: 10px; font-size: 12px; color: #1890ff;">
- 挂单只能选择一个产品
- </span>
- </el-form-item>
- <el-form-item label="发起人所属部门" prop="createDeptName">
- <el-input v-model="form.createDeptName" :disabled="true"></el-input>
- </el-form-item>
- <!-- <el-form-item prop="productionRequirements" label="备注">
- <el-input
- clearable
- v-model="form.productionRequirements"
- placeholder="请输入"
- type="textarea"
- />
- </el-form-item> -->
- <!-- <el-form-item label="预销售订单编码" prop="preOrderNo">
- <el-input
- clearable
- v-model="form.preOrderNo"
- placeholder="请输入"
- />
- </el-form-item> -->
-
-
- <!-- <el-form-item prop="productionRequirements" label="生产要求">
- <el-input
- clearable
- v-model="form.productionRequirements"
- placeholder="请输入"
- type="textarea"
- />
- </el-form-item> -->
- </el-col>
- <el-col :span="8">
- <el-form-item label="来源类型" prop="relationType">
- <el-select
- v-model="form.relationType"
- filterable
- clearable
- style="width: 100%"
- @change="clearContrcat"
- >
- <el-option :value="1" label="商机"></el-option>
- <el-option :value="2" label="报价"></el-option>
- <el-option :value="3" label="销售合同"></el-option>
- <el-option :value="4" label="项目"></el-option>
- <el-option
- v-if="form.saleType == 4 || form.saleType == 6"
- :value="5"
- label="退货单"
- ></el-option>
- </el-select>
- </el-form-item>
- <el-form-item
- label="报价单"
- prop="relationCode"
- v-if="form.relationType == 2"
- >
- <el-input
- clearable
- readonly
- @clear="clearContrcat"
- v-model="form.relationCode"
- @click.native="handQuotation"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item
- label="商机名称"
- prop="relationName"
- v-if="form.relationType == 1"
- >
- <el-input
- clearable
- v-model="form.relationName"
- @click.native="handOpportunity"
- readonly
- @clear="clearContrcat"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item
- label="选择合同"
- prop="relationName"
- v-if="form.relationType == 3"
- >
- <el-input
- clearable
- v-model="form.relationName"
- @click.native="handleContractBtn"
- @clear="clearContrcat"
- placeholder="请选择"
- :disabled="!!projectData.contractId"
- />
- </el-form-item>
- <el-form-item
- label="项目名称"
- prop="projectName"
- v-if="form.relationType == 4"
- >
- <el-input
- clearable
- v-model="form.projectName"
- @change="form.relationName = form.projectName"
- @clear="clearContrcat('project')"
- placeholder="请输入"
- style="width: calc(100% - 80px)"
- />
- <el-button
- style="margin-left: 5px"
- size="small"
- type="primary"
- @click.native="handleProjectBtn"
- >选择
- </el-button>
- </el-form-item>
- <el-form-item
- label="退货单"
- prop="relationCode"
- v-if="form.relationType == 5"
- >
- <el-input
- clearable
- readonly
- @clear="clearContrcat"
- v-model="form.relationCode"
- @click.native="handleReturnBtn"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item
- label="合同编号"
- prop="relationCode"
- v-if="form.relationType == 3"
- >
- <el-input
- :disabled="!!form.contractId"
- v-model="form.relationCode"
- />
- </el-form-item>
- <el-form-item
- label="业务员"
- prop="salesmanId"
- >
- <personSelect
- ref="salseManDirectorRef"
- v-model="form.salesmanId"
- @selfChange="salesmanChange"
- :init="false"
- />
- </el-form-item>
- <el-form-item
- label="总数"
- prop="totalPlanNum"
- v-if="form.needProduce == 4"
- >
- <el-input v-model="form.totalPlanNum" class="totalPlanNum">
- <template slot="append">
- <DictSelection
- dictName="计量单位"
- clearable
- v-model="form.planNumUnit"
- >
- </DictSelection>
- </template>
- </el-input>
- </el-form-item>
- <el-form-item prop="orderFiles" label="订单附件">
- <fileMain v-model="form.orderFiles"></fileMain>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="交易方式" prop="transactionMode">
- <el-select
- v-model="form.transactionMode"
- placeholder="请选择"
- @change="transactionModeChange"
- style="width: 100%"
- >
- <el-option
- v-for="item in transactionMethodsOp"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="发货模式" prop="deliveryMode">
- <el-select
- v-model="form.deliveryMode"
- placeholder="请选择"
- @change="deliveryModeChange"
- style="width: 100%"
- >
- <el-option
- v-for="item in shippingModeOp"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="结算方式" prop="settlementMode">
- <DictSelection
- dictName="结算方式"
- clearable
- @itemChange="settlementModeChange"
- v-model="form.settlementMode"
- >
- </DictSelection>
- </el-form-item>
- <el-form-item v-if="form.settlementMode == 1" label="结算日期范围" prop="settlementDate">
- <!-- <el-date-picker
- v-model="form.contractStartDate"
- @change="setDeliveryDays"
- type="date"
- placeholder="选择日期"
- style="width: 100%"
- >
- </el-date-picker> -->
- <el-date-picker
- style="width: 100%"
- v-model="form.settlementDate"
- type="daterange"
- :clearable="false"
- value-format="yyyy-MM-dd"
- range-separator="至"
- start-placeholder="开始日期"
- end-placeholder="结束日期"
- @change="settlementDateChange">
- </el-date-picker>
- </el-form-item>
- <el-form-item v-if="form.settlementMode == 2" label="结算月份范围" prop="settlementDate">
- <!-- <el-date-picker
- v-model="form.contractEndDate"
- type="date"
- placeholder="选择日期"
- style="width: 100%"
- >
- </el-date-picker> -->
- <el-date-picker
- v-model="form.settlementDate"
- :clearable="false"
- type="monthrange"
- range-separator="至"
- start-placeholder="开始月份"
- end-placeholder="结束月份"
- value-format="yyyy-MM"
- style="width: 100%"
- @change="settlementDateChange"
- >
- </el-date-picker>
- </el-form-item>
- <el-form-item v-if="form.settlementMode == 2" label="收款日期" prop="receiptDate">
- <el-input type="number" :min="1" :max="31" placeholder="请输入" v-model="form.receiptDate" @input="receiptDateChange">
- <template slot="prepend">每月</template>
- <template slot="append">日</template>
- </el-input>
- </el-form-item>
- <el-form-item
- label="期数"
- prop="issueNumber"
- >
- <el-input type="number" :min="1" v-model="form.issueNumber" @input="issueNumberChange">
- <template slot="append">
- <span>期</span>
- </template>
- </el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <headerTitle title="基本信息" v-if="form.needProduce != 2"></headerTitle>
- <el-row v-if="form.needProduce != 2">
- <el-col :span="12">
- <el-form-item label="客户名称" prop="partaName">
- <el-input
- clearable
- v-model="form.partaName"
- @click.native="handParent"
- placeholder="请选择"
- readonly
- :disabled="!!contactData?.id"
- />
- </el-form-item>
- <el-form-item
- label="客户统一社会信用代码"
- prop="partaUnifiedSocialCreditCode"
- class="form_item_label"
- >
- <el-input
- clearable
- v-model="form.partaUnifiedSocialCreditCode"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item label="客户联系人" prop="partaLinkName">
- <el-select
- v-model="form.partaLinkName"
- placeholder="请选择"
- @change="onchangeLink"
- style="width: 100%"
- >
- <el-option
- v-for="item in linkNameOptions"
- :key="item.id"
- :label="item.linkName"
- :value="item.id"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="客户电话" prop="partaTel">
- <el-input
- clearable
- :maxlength="20"
- v-model="form.partaTel"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item label="客户传真" prop="partaFax">
- <el-input clearable v-model="form.partaFax" placeholder="请输入" />
- </el-form-item>
- <el-form-item label=" 客户Email" prop="partaEmail">
- <el-input
- clearable
- v-model="form.partaEmail"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item label="客户地址" prop="partaAddress">
- <el-input
- clearable
- v-model="form.partaAddress"
- placeholder="请输入"
- />
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="售出方名称" prop="partbName">
- <el-input
- v-if="enterprisePage.length <= 1"
- clearable
- v-model="form.partbName"
- placeholder="请输入"
- />
- <el-select
- v-if="enterprisePage.length > 1"
- style="width: 100%"
- v-model="form.partbName"
- placeholder="请选择"
- @change="getEnterprise()"
- >
- <el-option
- v-for="item in enterprisePage"
- :key="item.id"
- :label="item.name"
- :value="item.name"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item
- label="售出方统一社会信用代码"
- prop="partbUnifiedSocialCreditCode"
- class="form_item_label"
- >
- <el-input
- clearable
- v-model="form.partbUnifiedSocialCreditCode"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item label="售出方联系人" prop="partbLinkName">
- <el-input
- clearable
- v-model="form.partbLinkName"
- @click.native="handHead"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item prop="partbTel" label="售出方联系电话">
- <el-input clearable v-model="form.partbTel" placeholder="请输入" />
- </el-form-item>
- <el-form-item prop="partbFax" label="售出方传真">
- <el-input clearable v-model="form.partbFax" placeholder="请输入" />
- </el-form-item>
- <el-form-item label="售出方Email" prop="partbEmail">
- <el-input
- clearable
- v-model="form.partbEmail"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item label="售出方地址" prop="partbAddress">
- <el-input
- clearable
- v-model="form.partbAddress"
- placeholder="请输入"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <headerTitle
- title="物品清单"
- style="margin-top: 30px"
- v-if="form.needProduce != 4"
- >
- <el-button
- type="primary"
- size="mini"
- style="margin-bottom: 5px"
- @click="orderListShow"
- v-if="!form.id"
- >历史记录</el-button
- ></headerTitle
- >
- <inventoryTable
- v-if="form.needProduce != 4"
- :isSuspend="form.isSuspend"
- :customerMark="customerMark"
- :isCustomerMark="clientEnvironmentId != 4 && form.needProduce != 2"
- :isProduceDeliveryDeadline="form.needProduce != 0"
- ref="inventoryTable"
- @setCountAmount="setCountAmount"
- :isContractId="!!form.contractId"
- :isChangeCount="false"
- :needProduce="form.needProduce"
- :isSupplier="true"
- :isArrivalWay="true"
- :cacheKeyUrl="cacheKeyUrl"
- :isGoods="true"
- :isTaxRate="isTaxRate"
- :isSinglePrice="form.needProduce != 2 && isSinglePrice != 0"
- :isBatchNo="isBatchNo == 1 && form.saleTypeName.includes('受托')"
- :isProductionRequirements="true"
- :isIncreaseTotalWeight="true"
- ></inventoryTable>
- <headerTitle
- title="类型清单"
- style="margin-top: 30px"
- v-if="form.needProduce == 4"
- ></headerTitle>
- <typeList
- v-if="form.needProduce == 4"
- @setCountAmount="setCountAmount"
- @setTotalPlanNum="setTotalPlanNum"
- ref="typeListRef"
- ></typeList>
- <!-- <el-row v-if="form.needProduce == 1">
- <el-col :span="8">
- <el-form-item
- label="自动生成采购计划:"
- label-width="160px"
- prop="generatePurchase"
- >
- <el-radio-group v-model="form.generatePurchase">
- <el-radio :label="1">是</el-radio>
- <el-radio :label="0">否</el-radio>
- </el-radio-group>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item
- label="自动生成生产计划:"
- label-width="160px"
- prop="generateProduce"
- >
- <el-radio-group v-model="form.generateProduce">
- <el-radio :label="1">是</el-radio>
- <el-radio :label="0">否</el-radio>
- </el-radio-group>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item
- label="自动生成项目立项:"
- label-width="160px"
- prop="generateProject"
- >
- <el-radio-group v-model="form.generateProject">
- <el-radio :label="1">是</el-radio>
- <el-radio :label="0">否</el-radio>
- </el-radio-group>
- </el-form-item>
- </el-col>
- </el-row> -->
- <el-row style="margin-top: 20px">
- <el-col :span="12">
- <el-form-item label="总金额" prop="totalAmount">
- {{ form.totalAmount || 0 }}元
- </el-form-item>
- <el-form-item label="收货地址" prop="receiveAddress">
- <el-input
- clearable
- type="textarea"
- v-model="form.receiveAddress"
- placeholder="请输入"
- />
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="优惠后总金额">
- <el-input
- type="number"
- :min="0"
- :max="form.totalAmount"
- clearable
- :disabled="!!form.contractId || !form.totalAmount"
- v-model="form.payAmount"
- @input="discountInput"
- placeholder="请输入"
- >
- <template slot="append">元</template>
- </el-input>
- </el-form-item>
- <el-form-item label="备注" prop="remark">
- <el-input
- clearable
- type="textarea"
- v-model="form.remark"
- placeholder="请输入"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row style="margin-top: 20px">
- <el-col :span="12">
- <el-form-item label="收货人信息" prop="receivePerson">
- <el-input clearable v-model="form.receivePerson" />
- </el-form-item>
- </el-col>
- </el-row>
- <div v-if="form.needProduce != 2 && form.needProduce != 4">
- <headerTitle
- title="收款计划"
- style="margin-top: 30px"
- ></headerTitle>
- <PaymentCollectionPlan
- ref="paymentCollectionPlanRef"
- menu="sale"
- :info="form"
- ></PaymentCollectionPlan>
- </div>
- </el-form>
- <div slot="footer" class="footer">
- <el-button type="primary" @click="save" v-click-once>保存</el-button>
- <el-button
- type="primary"
- v-if="isNeed_process_is_close"
- @click="save('sub')"
- v-click-once
- >提交</el-button
- >
- <el-button @click="cancel">返回</el-button>
- </div>
- <quotationList
- ref="quotationListRef"
- @changeParent="changeQuotationList"
- :isContractBook="false"
- ></quotationList>
- <!-- 商机 -->
- <opportunity-dialog
- :opportunityDialogFlag.sync="opportunityDialogFlag"
- v-if="opportunityDialogFlag"
- ref="opportunityDialogRef"
- @changeParent="getOpportunityDetail"
- ></opportunity-dialog>
- <parentList ref="parentRef" @changeParent="changeParent"></parentList>
- <head-list ref="headRef" @changeParent="changePersonel"></head-list>
- <contractListDialog
- ref="selectContractRef"
- @changeParent="changeContract"
- :contactData="contactData"
- :isCreatedByOrder="2"
- ></contractListDialog>
- <projectListDialog
- :contactData="contactData"
- ref="selectProjectRef"
- @changeParent="changeProject"
- ></projectListDialog>
- <process-submit-dialog
- :isNotNeedProcess="true"
- :processSubmitDialogFlag.sync="processSubmitDialogFlag"
- v-if="processSubmitDialogFlag"
- ref="processSubmitDialogRef"
- @reload="reload"
- :callBack="callBack"
- ></process-submit-dialog>
- <bomDialog
- ref="bomDialogRef"
- @handleSubmit="bomDialogSuccess"
- @reload="reload"
- ></bomDialog>
- <saleOrderListDialog
- ref="saleOrderListDialogRef"
- :isMy="true"
- @changeParent="saleOrderListDialogChange"
- ></saleOrderListDialog>
- <!-- 退货 -->
- <return-order-dialog
- :returnOrderDialogFlag.sync="returnOrderDialogFlag"
- v-if="returnOrderDialogFlag"
- @changeParent="changeReturn"
- >
- </return-order-dialog>
- </ele-modal>
- </template>
- <script>
- import { emailReg, numberReg, telReg } from 'ele-admin';
- import inventoryTable from '@/BIZComponents/inventoryTable.vue';
- import fileUpload from '@/components/upload/fileUpload';
- import dictMixins from '@/mixins/dictMixins';
- import parentList from '@/views/saleManage/contact/components/parentList.vue';
- import {
- getDetail,
- updateContractStatus
- } from '@/api/contractManage/contractBook';
- import {
- contactDetail,
- updateRelationStatus
- } from '@/api/saleManage/contact';
- import {
- getSaleOrderDetail,
- UpdateInformation,
- addInformation,
- submit,
- getByRepeatBomAttribute,
- saveOrderBomList
- } from '@/api/saleManage/saleorder';
- import { getDetail as getOpportunityInfo } from '@/api/saleManage/businessOpportunity';
- import { getcontactlink } from '@/api/saleManage/businessFollow';
- import headList from '@/BIZComponents/user-select/user-select.vue';
- import contractListDialog from './contractListDialog.vue';
- import projectListDialog from './projectListDialog.vue';
- import paymentList from './paymentList.vue';
- import { listOrganizations, listOrganizationsNew } from '@/api/system/organization';
- import { copyObj } from '@/utils/util';
- import { enterprisePage } from '@/api/contractManage/contractBook';
- // import fileMain from '@/components/addDoc/index.vue';
- import processSubmitDialog from '@/BIZComponents/processSubmitDialog/processSubmitDialog.vue';
- import { getUserDetail } from '@/api/system/organization/index.js';
- import typeList from './typeList.vue';
- import bomDialog from './bomDialog';
- import saleOrderListDialog from '@/views/saleManage/saleOrder/invoice/components/orderListDialog.vue';
- import { parameterGetByCode } from '@/api/main/index.js';
- import quotationList from '@/views/contractManage/contractBook/components/quotationList.vue';
- import returnOrderDialog from '@/views/saleManage/saleOrder/customerReturnOrder/returnOrderDialog.vue';
- import opportunityDialog from '@/views/financialManage/components/opportunityDialog.vue';
- import { mapGetters } from 'vuex';
- import personSelect from '@/components/CommomSelect/person-select.vue';
- import PaymentCollectionPlan from '@/BIZComponents/paymentCollectionPlan/Index.vue'
- import { shippingModeOp, transactionMethodsOp } from '@/enum/dict.js';
- export default {
- mixins: [dictMixins],
- components: {
- processSubmitDialog,
- returnOrderDialog,
- // fileMain,
- fileUpload,
- headList,
- contractListDialog,
- projectListDialog,
- paymentList,
- inventoryTable,
- parentList,
- typeList,
- bomDialog,
- quotationList,
- saleOrderListDialog,
- opportunityDialog,
- personSelect,
- PaymentCollectionPlan
- },
- props: {
- contactData: {
- type: Object,
- default: () => {
- return {};
- }
- },
- isRequired: {
- type: Boolean,
- default: true
- }
- },
- data() {
- let formDef = {
- id: '',
- isSuspend: 0,
- contractId: '',
- orderFiles: [],
- contractName: '',
- projectName: '',
- projectId: '',
- pricingWay: 1,
- receiptDate: 1,
- payAmount: '',
- generatePurchase: 0,
- generateProduce: 0,
- generateProject: 0,
- projectName: '',
- projectId: '',
- receiveAddress: '',
- remark: '',
- saleType: '',
- saleTypeName: '',
- totalAmount: 0,
- settlementMode: '4',
- settlementModeName: '分期付款',
- partaUnifiedSocialCreditCode: '',
- partbUnifiedSocialCreditCode: '',
- productionRequirements: '',
- partaAddress: '',
- partaEmail: '',
- partaFax: '',
- partaId: '',
- partaLinkId: '',
- partaLinkName: '',
- partaName: '',
- partaTel: '',
- partbAddress: '',
- partbEmail: '',
- partbFax: '',
- partbId: '',
- partbLinkId: '',
- partbLinkName: '',
- partbName: '',
- partbTel: '',
- needProduce: 1,
- planNumUnit: '立方',
- receivePerson: '',
- relationType: '',
- relationName: '',
- relationCode: '',
- relationId: '',
- createDeptName: '',
- salesmanId: '',
- salesDeptId: '',
- salesDeptName: '',
- issueNumber: 1,
- transactionMode: 1,
- deliveryMode: 1,
- settlementDate: [],
- endSettlementDate: '',
- startSettlementDate: ''
- };
- return {
- shippingModeOp,
- transactionMethodsOp,
- // settlementDate: [],
- returnOrderDialogFlag: false,
- customerMark: '',
- opportunityDialogFlag: false,
- projectData: {}, //项目数据
- clearing: false, //是否清除合同
- processSubmitDialogFlag: false,
- fullscreen: false, //全屏
- linkNameOptions: [],
- cacheKeyUrl: 'eos-saleManage-saleOrder-inventoryTable',
- visible: false,
- title: '',
- formDef,
- form: copyObj(formDef),
- tableLinkData: [],
- // 组织机构树形结构数据
- groupTreeData: [],
- groupData: [],
- tableList: [],
- // rules: {
- // settlementMode: [
- // { required: true, message: '请选择结算方式', trigger: 'change' }
- // ],
- // saleType: [
- // { required: true, message: '请选择销售类型', trigger: 'change' }
- // ],
- // partaName: [
- // { required: true, message: '请选择客户名称', trigger: 'change' }
- // ],
- // partaLinkName: [
- // { required: true, message: '请选择客户联系人', trigger: 'change' }
- // ],
- // acceptUnpack: [
- // { required: true, message: '请选择是否接受', trigger: 'change' }
- // ],
- // partaTel: [
- // {
- // required: true,
- // pattern: telReg,
- // message: '请输入客户联系电话',
- // trigger: 'blur'
- // }
- // ],
- // partbName: [
- // { required: true, message: '请输入售出方名称', trigger: 'change' }
- // ],
- // partbLinkName: [
- // { required: true, message: '请输入售出方联系人', trigger: 'change' }
- // ],
- // partbTel: [
- // {
- // required: true,
- // pattern: telReg,
- // message: '请输入售出方联系电话',
- // trigger: 'blur'
- // }
- // ],
- // partaEmail: [
- // { pattern: emailReg, message: '邮箱格式不正确', trigger: 'blur' }
- // ],
- // payAmount: [{ required: true, message: '请输入', trigger: 'blur' }]
- // },
- // 提交状态
- loading: false,
- // 是否是修改
- isUpdate: false,
- enterprisePage: [],
- businessId: '',
- isBatchNo: 0,
- isTaxRate: 0,
- isSinglePrice: 0,
- isDeptAndPerson: 0
- };
- },
- computed: {
- ...mapGetters(['user']),
- clientEnvironmentId() {
- return this.$store.state.user.info.clientEnvironmentId;
- },
- rules() {
- let isRequired = this.isRequired;
- return {
- settlementMode: [
- {
- required: this.getSaleTypeName(this.form.saleType) ? false : true,
- message: '请选择结算方式',
- trigger: 'change'
- }
- ],
- saleType: [
- { required: true, message: '请选择销售类型', trigger: 'change' }
- ],
- projectName: [
- {
- required: this.clientEnvironmentId == 4 ? true : false,
- message: '请选择项目',
- trigger: 'change'
- }
- ],
- partaName: [
- { required: true, message: '请选择客户名称', trigger: 'change' }
- ],
- partaLinkName: [
- {
- required: isRequired,
- message: '请选择客户联系人',
- trigger: 'change'
- }
- ],
- acceptUnpack: [
- { required: true, message: '请选择是否接受', trigger: 'change' }
- ],
- partaTel: [
- {
- required: isRequired,
- pattern: telReg,
- message: '请输入客户联系电话',
- trigger: 'blur'
- }
- ],
- partbName: [
- { required: true, message: '请输入售出方名称', trigger: 'change' }
- ],
- partbLinkName: [
- {
- required: isRequired,
- message: '请输入售出方联系人',
- trigger: 'change'
- }
- ],
- partbTel: [
- {
- required: isRequired,
- pattern: telReg,
- message: '请输入售出方联系电话',
- trigger: 'blur'
- }
- ],
- partaEmail: [
- { pattern: emailReg, message: '邮箱格式不正确', trigger: 'blur' }
- ],
- payAmount: [{ required: true, message: '请输入', trigger: 'blur' }],
- salesmanId: [{ required: this.isDeptAndPerson == 1 ? true : false, message: '请选择业务员', trigger: 'change' }],
- salesDeptId: [{ required: this.isDeptAndPerson == 1 ? true : false, message: '请选择销售部门', trigger: 'change' }],
- };
- }
- },
- created() {
- console.log('user', this.user.info);
- this.changePersonel();
- this.getGroupAll();
- this.getEnterprisePage();
- //批次号是否必填//0否 1是
- parameterGetByCode({
- code: 'eom_saleOrder_entrusted_batchNo'
- }).then((res) => {
- this.isBatchNo = res.value;
- });
- // 销售部门是否必填//0否 1是
- parameterGetByCode({
- code: 'eom_saleOrder_Dept_and_person'
- }).then((res) => {
- this.isDeptAndPerson = res.value;
- console.log('isDeptAndPerson', this.isDeptAndPerson);
- });
- // 税率是否必填//0否 1是
- parameterGetByCode({
- code: 'eom_saleOrder_order-taxRate'
- }).then((res) => {
- this.isTaxRate = res.value;
- });
- // 单价是否必填//0否 1是
- parameterGetByCode({
- code: 'eom_saleOrder_single_price'
- }).then((res) => {
- this.isSinglePrice = res.value;
- console.log('isSinglePrice', this.isSinglePrice);
- });
- },
- methods: {
- setCountAmount(allPrice, discountTotalPrice) {
- this.form.totalAmount = allPrice;
- this.form.payAmount = discountTotalPrice ? discountTotalPrice : allPrice;
- this.$refs.paymentCollectionPlanRef?.setDiscountAmount(this.form.payAmount);
- },
- setTotalPlanNum(totalPlanNum) {
- this.$set(this.form, 'totalPlanNum', totalPlanNum);
- },
- discountInput() {
- this.$refs.inventoryTable.discountInputByOrder(this.form.payAmount);
- this.$refs.paymentCollectionPlanRef?.setDiscountAmount(this.form.payAmount);
- },
- // 选择负责人部门
- change_principalDep(id) {
- const info = this.groupData.find((e) => e.id == id);
- this.form.salesDeptName = info?.name;
- this.form.salesmanId = '';
- this.form.salesmanName = '';
- // 根据部门获取人员
- this.$nextTick(() => {});
- this.getSalesmanUser(id);
- },
- getSalesmanUser(groupId) {
- if (groupId) {
- this.$refs.salseManDirectorRef.getList({ groupId });
- }
- },
- salesmanChange(val, info) {
- this.$set(this.form, 'salesmanId', val);
- this.$set(this.form, 'salesmanName', info.name);
- },
- // 获取公司数据
- getGroupAll() {
- const apiRequest = this.clientEnvironmentId == 6 ? listOrganizationsNew({deptIds: ['1998632792148717569', '1998632872721297409']}) : listOrganizations();
- apiRequest.then((list) => {
- console.log('listOrganizations', list);
- this.groupData = list;
- this.groupTreeData = this.$util.toTreeData({
- data: list,
- idField: 'id',
- parentIdField: 'parentId'
- });
- });
- },
- //选择商机
- handOpportunity(e) {
- this.opportunityDialogFlag = true;
- this.$nextTick(() => {
- let item = {
- id: this.form.sourceId
- };
- this.$refs.opportunityDialogRef.init(item);
- });
- },
- //获取商机信息
- async getOpportunityDetail(row) {
- this.$set(this.form, 'relationName', row.name);
- this.$set(this.form, 'relationId', row.id);
- this.$set(this.form, 'relationCode', row.code);
- let cusInfo = await contactDetail(row.contactId);
- let info = await getOpportunityInfo(row?.id ?? '');
- await this.getLinkInfo(cusInfo.base.id);
- let totalPrice = info.productList.reduce((num, cur) => {
- return num + Number(cur.totalPrice);
- }, 0);
- info.productList.forEach((item) => {
- item.discountSinglePrice =
- item.discountSinglePrice || item.singlePrice;
- item.discountTotalPrice = item.discountTotalPrice || item.totalPrice;
- });
- let discountTotalPrice = info.productList.reduce((num, cur) => {
- return num + Number(cur.discountTotalPrice);
- }, 0);
- this.form = Object.assign({}, this.form, {
- partaName: cusInfo.base.name,
- partaId: cusInfo.base.id,
- partaUnifiedSocialCreditCode: cusInfo.base.unifiedSocialCreditCode,
- partaAddress: cusInfo.base.addressName + cusInfo.base.address,
- partaLinkName: cusInfo.linkList[0]?.linkName,
- partaLinkId: cusInfo.linkList[0]?.id,
- partaTel: cusInfo.linkList[0]?.mobilePhone,
- totalPrice: totalPrice,
- discountTotalPrice: discountTotalPrice
- });
- if (this.enterprisePage.length === 1) {
- this.form.partbName = this.enterprisePage[0].name;
- this.form.partbId = this.enterprisePage[0].id;
- this.getEnterprise();
- }
- this.$nextTick(() => {
- this.$refs.inventoryTable &&
- this.$refs.inventoryTable.putTableValue(info);
- });
- // let form = {
- // contractVO: {
- // },
- // productList: info.productList || []
- // };
- },
- //选择报价单
- handQuotation(e) {
- this.$refs.quotationListRef.open();
- },
- //报价单
- async changeQuotationList({ data, sourceCode, sourceId }) {
- this.form = Object.assign({}, this.form, {
- relationCode: sourceCode,
- relationId: sourceId
- });
- this.getDetailData('', data);
- },
- //选择退货单
- handleReturnBtn(e) {
- // this.$refs.returnListRef.open();
- if (e.target.nodeName == 'I') {
- this.$set(this.form, 'relationCode', '');
- this.$set(this.form, 'relationId', '');
- return;
- }
- this.returnOrderDialogFlag = true;
- },
- //退货单
- async changeReturn(row) {
- console.log('data~~~', row);
- this.form = Object.assign({}, this.form, {
- relationCode: row.returnNo,
- relationId: row.id
- });
- this.getReturnOrderDetail(row);
- },
- async getReturnOrderDetail(row) {
- console.log('row', row.orderNo);
- // let data = null;
- // if (row) {
- // data = row;
- // } else {
- // data = await getSaleOrderDetail(id);
- // }
- const id = row.orderIds.split(',')[0];
- const res = await getSaleOrderDetail(id);
- console.log('res~~~~', res);
- // this.form = Object.assign({}, this.form, res);
- if (row.partaId) {
- await this.changeParent({ id: row.partaId }, true);
- }
- if (res) {
- let {
- partaAddress,
- partaEmail,
- partaFax,
- partaId,
- partaLinkId,
- partaLinkName,
- partaName,
- partaTel,
- partbAddress,
- partbEmail,
- partbFax,
- partbId,
- partbLinkId,
- partbLinkName,
- partbName,
- partbTel,
- totalPrice,
- discountTotalPrice,
- partaUnifiedSocialCreditCode,
- partbUnifiedSocialCreditCode,
- settlementMode,
- settlementModeName,
- pricingWay,
- productList,
- typedetailList,
- totalAmount,
- payAmount
- } = res;
- this.form = Object.assign({}, this.form, {
- partaAddress,
- partaEmail,
- partaFax,
- partaId,
- partaLinkId,
- partaLinkName,
- partaName,
- partaTel,
- partbAddress,
- partbEmail,
- partbFax,
- partbId,
- partbLinkId,
- partbLinkName,
- partbName,
- partbTel,
- totalPrice,
- discountTotalPrice,
- partaUnifiedSocialCreditCode,
- partbUnifiedSocialCreditCode,
- settlementMode,
- settlementModeName,
- pricingWay,
- productList,
- typedetailList,
- totalAmount,
- payAmount
- });
- this.$nextTick(() => {
- this.$refs.inventoryTable &&
- this.$refs.inventoryTable.putTableValue(res);
- this.$refs.typeListRef &&
- this.$refs.typeListRef.putTableValue(res.typedetailList);
- this.getLinkInfo(row.partaId);
- // this.$store.commit('order/setContractId', row.partaId);
- });
- }
- },
- //选择合同获取合同的详情
- async getDetailData(id, row) {
- this.loading = true;
- let data = null;
- if (row) {
- data = row;
- } else {
- data = await getDetail(id);
- }
- this.loading = false;
- if (data) {
- await this.changeParent({ id: data.contractVO?.partaId }, true);
- let { contractVO } = data;
-
- this.$nextTick(() => {
- let {
- partaAddress,
- partaEmail,
- partaFax,
- partaId,
- partaLinkId,
- partaLinkName,
- partaName,
- partaTel,
- partbAddress,
- partbEmail,
- partbFax,
- partbId,
- partbLinkId,
- partbLinkName,
- partbName,
- partbTel,
- totalPrice,
- discountTotalPrice,
- partaUnifiedSocialCreditCode,
- partbUnifiedSocialCreditCode,
- settlementMode,
- settlementModeName,
- pricingWay,
- contractNo,
- contractNumber,
- contractName,
- businessDeptId,
- businessDeptName,
- businessUserId,
- businessUserName,
- transactionMode,
- startSettlementDate,
- receiptDate,
- issueNumber,
- endSettlementDate,
- deliveryMode,
- } = contractVO;
- if(businessDeptId){
- this.getSalesmanUser(businessDeptId);
- }
- this.form = Object.assign(
- {},
- this.form,
- {
- partaAddress,
- partaEmail,
- partaFax,
- partaId,
- partaLinkId,
- partaLinkName,
- partaName,
- partaTel,
- partbAddress,
- partbEmail,
- partbFax,
- partbId,
- partbLinkId,
- partbLinkName,
- partbName,
- partbTel,
- pricingWay,
- totalPrice,
- discountTotalPrice,
- partaUnifiedSocialCreditCode,
- partbUnifiedSocialCreditCode,
- totalAmount: totalPrice,
- payAmount: discountTotalPrice || totalPrice,
- receiveAddress: this.clientEnvironmentId == 5 ? '' : partaAddress,
- settlementMode,
- settlementModeName,
- contractNo,
- contractNumber,
- salesDeptId: businessDeptId,
- salesDeptName: businessDeptName,
- salesmanId: businessUserId,
- salesmanName: businessUserName,
- transactionMode,
- startSettlementDate,
- receiptDate,
- issueNumber,
- endSettlementDate,
- deliveryMode,
- settlementDate: startSettlementDate ? [startSettlementDate, endSettlementDate] : [],
- },
- !row
- ? {
- relationName: contractName,
- relationCode: contractNumber,
- relationId: id
- }
- : {}
- );
- data.productList = data.productList.map((item) => {
- item['saleCount'] = item.contractCount || item.saleCount;
- item['saleUnit'] = item.contractUnit || item.saleUnit;
- item['saleUnitId'] = item.contractUnitId || item.saleUnitId;
- return item;
- });
- const receiptData = {
- receiptPaymentList: data.receiptPaymentList,
- payAmount: discountTotalPrice
- }
- this.$refs.paymentCollectionPlanRef &&
- this.$refs.paymentCollectionPlanRef.putTableValue(receiptData);
- this.getLinkInfo(partaId);
- this.$refs.inventoryTable &&
- this.$refs.inventoryTable.putTableValue(data);
-
-
- });
- }
- },
- //获取订单详情
- async getSaleOrderDetail(id) {
- this.businessId = id;
- this.loading = true;
- const data = await getSaleOrderDetail(id);
- this.loading = false;
- data.settlementDate = data.startSettlementDate ? [data.startSettlementDate, data.endSettlementDate] : [];
- this.form = data;
- if (data.partaId) {
- await this.changeParent({ id: data.partaId }, true);
- }
- if (data) {
- data.saleType = +data.saleType;
- this.$nextTick(() => {
- if(data.salesDeptId) {
- this.getSalesmanUser(data.salesDeptId);
- }
- this.$refs.inventoryTable &&
- this.$refs.inventoryTable.putTableValue(data);
- this.$refs.typeListRef &&
- this.$refs.typeListRef.putTableValue(data.typedetailList);
-
- this.getLinkInfo(data.partaId);
- console.log('paymentCollectionPlanRef~~~~', data);
-
- this.$refs.paymentCollectionPlanRef && this.$refs.paymentCollectionPlanRef.putTableValue(data);
- // this.$refs.paymentCollectionPlanRef.setDiscountAmount(data.payAmount);
- this.$store.commit('order/setContractId', data.partaId);
- });
- }
- },
- //更新联系人数据
- async getLinkInfo(contactId) {
- const data = await getcontactlink({ contactId });
- if (data && data?.length) {
- this.linkNameOptions = data;
- }
- },
- //选择下拉框
- onchangeLink(selectedOptions) {
- const option = this.linkNameOptions.find(
- (opt) => opt.id === selectedOptions
- );
- this.form = Object.assign({}, this.form, {
- partaEmail: option?.email,
- partaLinkName: option?.linkName || '',
- partaTel: option?.mobilePhone || option?.phone || '',
- partaLinkId: option?.id
- });
- },
- handHead() {
- let item = {
- id: this.form.partbLinkId
- };
- this.$refs.headRef.open(item);
- },
- orderListShow() {
- this.$refs.saleOrderListDialogRef.open();
- },
- async saleOrderListDialogChange(row) {
- let data = await getSaleOrderDetail(row.id);
- [
- 'id',
- 'orderId',
- 'createTime',
- 'createUserId',
- 'createUserName',
- 'createDept',
- 'orderNo',
- 'orderStatus',
- 'outboundStatus',
- 'payStatus',
- 'preOrderNo',
- 'progress',
- 'processInstanceId',
- 'orderBomList'
- ].forEach((key) => {
- delete data[key];
- data.productList.forEach((item) => {
- if (['id', 'createTime', 'createUserId', 'orderId'].includes(key)) {
- delete item[key];
- }
- });
- data.typedetailList.forEach((item) => {
- if (['id', 'createTime', 'createUserId', 'orderId'].includes(key)) {
- delete item[key];
- }
- });
- });
- this.form = data;
- if (data) {
- data.saleType = +data.saleType;
- this.$nextTick(() => {
- this.$refs.inventoryTable &&
- this.$refs.inventoryTable.putTableValue(data);
- this.$refs.typeListRef &&
- this.$refs.typeListRef.putTableValue(data.typedetailList);
- this.getLinkInfo(data.partaId);
- this.$store.commit('order/setContractId', data.partaId);
- });
- }
- },
- //选择售出方人回调
- changePersonel(obj) {
- if (!obj) {
- obj = this.$store.getters.user.info;
- obj.id = obj.userId;
- }
- this.$set(this.form, 'partbLinkId', obj.id);
- this.$set(this.form, 'partbLinkName', obj.name);
- this.$set(this.form, 'partbTel', obj.phone);
- this.$set(this.form, 'partbEmail', obj.email);
- },
- //选择客户回调
- async changeParent(obj, isCustomerMark) {
- const { base, other, linkList } = await contactDetail(obj.id);
- const userInfo = base?.salesmanId
- ? await getUserDetail(base?.salesmanId)
- : {};
- this.customerMark = base?.serialNo;
- // 新增时带出默认收货人
- const defaultReceived = linkList.find((item) => item.isDefault === 1);
- this.form.receivePerson = defaultReceived?.linkName;
- if (isCustomerMark) {
- return;
- }
- this.form = Object.assign({}, this.form, {
- partaId: base?.id,
- partaName: base?.name,
- partaAddress: other?.addressName + other?.address,
- partaLinkId: '',
- partaLinkName: '',
- partaEmail: '',
- partaTel: '',
- partaUnifiedSocialCreditCode: base?.unifiedSocialCreditCode,
- customerMark: base?.serialNo,
- receiveAddress: this.clientEnvironmentId == 5 ? '' : other?.addressName + other?.address,
- receivePerson: defaultReceived?.linkName
- });
- this.changePersonel(userInfo?.id ? userInfo : '');
- await this.getLinkInfo(obj.id);
- this.$nextTick(() => {
- let firstLink =
- this.linkNameOptions.find((item) => item.ifChief == 1) || {};
- this.form = Object.assign({}, this.form, {
- partaLinkId: firstLink.id || this.linkNameOptions[0]?.id,
- partaLinkName:
- firstLink.linkName || this.linkNameOptions[0]?.linkName,
- partaTel:
- firstLink.mobilePhone || this.linkNameOptions[0]?.mobilePhone
- });
- this.setProductInfo();
- });
- },
- setProductInfo() {
- if (this.$refs.inventoryTable && this.$refs.inventoryTable.form) {
- this.$refs.inventoryTable?.form?.datasource.forEach((item, index) => {
- this.$set(
- this.$refs.inventoryTable?.form?.datasource[index],
- 'customerMark',
- this.customerMark
- );
- });
- }
- },
- saleTypeChange() {
- if (this.getSaleTypeName()) {
- this.$set(this.form, 'settlementMode', '');
- }
- },
- getSaleTypeName() {
- let saleTypeName =
- this.getDictValue('销售类型', this.form.saleType) || '';
- this.form.saleTypeName = saleTypeName;
- if (
- saleTypeName.indexOf('技改') != '-1' ||
- saleTypeName.indexOf('三包') != '-1' ||
- saleTypeName.indexOf('补发') != '-1'
- ) {
- return true;
- } else {
- return false;
- }
- },
- //选择合同回调
- changeContract(obj) {
- this.form = Object.assign({}, this.form, {
- contractId: obj.id,
- contractName: obj.contractName,
- relationType: 3,
- productionRequirements: obj.productionRequirements
- });
- this.getDetailData(obj.id);
- this.$store.commit('order/setContractId', obj.id);
- },
- //选择合同弹框
- handleContractBtn() {
- if (this.clearing) return;
- let item = {
- id: this.form.contractId
- };
- this.$refs.selectContractRef.open(item);
- },
- //选择项目回调
- async changeProject(obj) {
- this.projectData = obj;
- this.form = Object.assign({}, this.form, {
- projectName: obj.name,
- projectId: obj.id,
- projectCode: obj.code,
- relationName: obj.name,
- relationId: obj.id,
- relationCode: obj.code
- });
- if (obj.contractId) {
- this.changeContract({
- id: obj.contractId,
- contractName: obj.contractName
- });
- } else if (obj.contactId) {
- this.changeParent({ id: obj.contactId });
- }
- },
- //选择项目弹框
- handleProjectBtn() {
- if (this.clearing) return;
- let item = {
- id: this.form.projectId
- };
- this.$refs.selectProjectRef.open(item);
- },
- //清除合同
- clearContrcat(type) {
- if (type == 'project' && !this.form.projectId) {
- return;
- }
- this.clearing = true;
- let { id, saleType, saleTypeName, orderFiles, remark, relationType } =
- this.form;
- this.form = Object.assign({}, copyObj(this.formDef), {
- id,
- saleType,
- saleTypeName,
- relationType,
- orderFiles,
- remark,
- createDeptName: this.user.info.groupName
- });
- this.projectData = {};
- this.$store.commit('order/setContractId', '');
- this.$refs.inventoryTable &&
- this.$refs.inventoryTable.putTableValue([]);
- setTimeout(() => {
- this.clearing = false;
- }, 500);
- },
- handParent() {
- if (this.form.contractId) {
- return this.$message.error('选择了合同不能更改客户名称');
- }
- let item = {
- id: this.form.contactId
- };
- this.$refs.parentRef.open(item);
- },
- listFormatte(data) {
- return data.filter((item) => item.dictCode !== 0);
- },
- //打开新增编辑弹框
- async open(type, row, contactCategoryId) {
- this.businessId = '';
- this.title = type === 'add' ? '新增' : '修改';
- // this.clientEnvironmentId =
- // this.$store.state.user.info.clientEnvironmentId;
- this.row = row;
- if (this.enterprisePage.length == 0) {
- await this.getEnterprisePage();
- }
- this.visible = true;
- if (type == 'add') {
- this.isUpdate = false;
- if (this.enterprisePage.length > 0) {
- this.form.partbName = this.enterprisePage[0].name;
- this.form.partbId = this.enterprisePage[0].id;
- this.form.partbUnifiedSocialCreditCode =
- this.enterprisePage[0].unifiedSocialCreditCode;
- this.form.partbFax = this.enterprisePage[0].fax;
- this.form.partbAddress = this.enterprisePage[0].address;
- }
- if (this.contactData.id) {
- this.changeParent({ id: this.contactData.id });
- }
- this.form.createDeptName = this.user.info.groupName;
- this.form.saleType = 1;
- this.$nextTick(() => {
- this.issueNumberChange(this.form.issueNumber);
- })
- // this.form.progress = 700;
- //嘉实默认值
- if (this.clientEnvironmentId == 5) {
- this.form.saleType = 2;
- this.form.needProduce = 0;
- this.form.progress = 700;
- this.form.settlementMode = '6';
- }
- //宝悦默认值
- if (this.clientEnvironmentId == 4) {
- this.form.needProduce = 4;
- this.form.relationType = 4;
- }
- //润天默认值
- if (this.clientEnvironmentId == 6) {
- this.form.salesDeptId = '1998632792148717569';
- this.form.salesDeptName = '营销部';
- this.$nextTick(() => {
- this.getSalesmanUser(this.form.salesDeptId)
- })
- }
- } else {
- this.isUpdate = true;
- this.getSaleOrderDetail(row.id);
- }
- },
- needProduceChange() {
- this.$nextTick(() => {
- this.form.totalAmount = 0;
- this.form.payAmount = 0;
- this.form.progress = this.form.needProduce == 0 ? 700 : 0;
- this.$refs.inventoryTable &&
- this.$refs.inventoryTable.putTableValue({});
- this.$refs.typeListRef && this.$refs.typeListRef.putTableValue([]);
- });
- },
- //从合同页面新增订单
- async contractOpen(row) {
- this.title = '新增';
- this.visible = true;
- this.isUpdate = false;
- if (this.enterprisePage.length == 0) {
- await this.getEnterprisePage();
- }
- if (this.enterprisePage.length > 0) {
- this.form.partbName = this.enterprisePage[0].name;
- this.form.partbId = this.enterprisePage[0].id;
- this.form.partbUnifiedSocialCreditCode =
- this.enterprisePage[0].unifiedSocialCreditCode;
- this.form.partbFax = this.enterprisePage[0].fax;
- this.form.partbAddress = this.enterprisePage[0].address;
- }
- this.form.createDeptName = this.user.info.groupName;
- await this.changeContract(row);
- },
- getEnterprisePage() {
- enterprisePage({
- pageNum: 1,
- size: 100
- }).then((res) => {
- this.enterprisePage = [];
- this.enterprisePage.push(...res.list);
- });
- },
- getEnterprise() {
- let data = this.enterprisePage.find(
- (item) => item.name == this.form.partbName
- );
- this.form.partbName = data.name;
- this.form.partbId = data.id;
- this.form.partbUnifiedSocialCreditCode = data.unifiedSocialCreditCode;
- this.form.partbFax = data.fax;
- this.form.partbAddress = data.address;
- },
- // 交易方式改变
- transactionModeChange(v) {
- },
- // 配送方式改变
- deliveryModeChange(v) {
- },
- // 结算方式改变
- settlementModeChange(v) {
- console.log('v~~~', v.dictCode);
- this.form.settlementModeName = v.dictValue;
- // this.$set(this.form, 'issueNumber', 1);
- this.$set(this.form, 'settlementDate', []);
- this.$set(this.form, 'receiptDate', 1);
-
- if(v.dictCode == 3) {
- this.$set(this.form, 'issueNumber', 2);
- } else {
- this.$set(this.form, 'issueNumber', 1);
- }
- this.$refs.paymentCollectionPlanRef?.defaultList(v.dictCode, this.form.issueNumber);
- },
- ifChiefChange(value, idx) {
- if (value === 1) {
- this.tableLinkData.forEach((e) => (e.ifChief = 0));
- this.tableLinkData[idx].ifChief = 1;
- }
- },
- getValidate() {
- console.log(this.form);
- let arr = [
- new Promise((resolve, reject) => {
- this.$refs.form.validate((valid) => {
- if (!valid) {
- reject(false);
- } else {
- resolve(true);
- }
- });
- })
- ];
- if (this.form.needProduce != 4) {
- arr.push(
- new Promise((resolve, reject) => {
- this.$refs.inventoryTable.validateForm((valid) => {
- if (!valid) {
- reject(false);
- } else {
- resolve(true);
- }
- });
- })
- );
- }
- if (this.form.needProduce == 4) {
- arr.push(
- new Promise((resolve, reject) => {
- this.$refs.typeListRef.validateForm((valid) => {
- if (!valid) {
- reject(false);
- } else {
- resolve(true);
- }
- });
- })
- );
- }
- if(this.form.needProduce != 2 && this.form.needProduce != 4) {
- arr.push(
- new Promise((resolve, reject) => {
- this.$refs.paymentCollectionPlanRef.validateForm((valid) => {
- if (!valid) {
- reject(false);
- } else {
- resolve(true);
- }
- });
- })
- );
- }
-
- return Promise.all(arr);
- },
- async save(type) {
- try {
- await this.getValidate();
-
- // 表单验证通过,执行保存操作
- this.loading = true;
- let isTemporary = [];
- if (!this.isUpdate) {
- delete this.form.id;
- }
- let commitData = Object.assign({}, this.form, {
- productList: this.$refs?.inventoryTable?.getTableValue() || [],
- typedetailList: this.$refs?.typeListRef?.getTableValue() || [],
- saleTypeName: this.getDictValue('销售类型', this.form.saleType),
- receiptPaymentList: this.$refs?.paymentCollectionPlanRef?.getTableValue() || [],
- endSettlementDate: this.form.settlementDate.length ?this.form.settlementDate[1] : '',
- startSettlementDate: this.form.settlementDate.length ? this.form.settlementDate[0] : ''
- // progress: this.form.needProduce == 0 ? 700 : 0
- });
- if(commitData.isSuspend == 1 && commitData.productList?.length > 1){
- this.$message.error('挂起订单只能选择一个产品');
- return;
- }
- if(commitData.needProduce != 2 && commitData.needProduce != 4) {
- const ratioSum = commitData.receiptPaymentList.reduce((acc, cur) => acc + +cur.ratio, 0);
- if(+ratioSum != 100){
- this.$message.error('比例合计必须为100%');
- return;
- }
- let receiptPaymentListSum = commitData.receiptPaymentList.reduce((acc, cur) => acc + +cur.price, 0);
- const payAmount = +commitData.payAmount;
-
- if(+ratioSum == 100) {
- const difference = payAmount - receiptPaymentListSum;
- if (Math.abs(difference) > 0.01 && commitData.receiptPaymentList.length > 0) {
- const lastIndex = commitData.receiptPaymentList.length - 1;
- commitData.receiptPaymentList[lastIndex].price = (+commitData.receiptPaymentList[lastIndex].price + difference).toFixed(2);
- receiptPaymentListSum = commitData.receiptPaymentList.reduce((acc, cur) => acc + +cur.price, 0);
- }
- }
- console.log('receiptPaymentListSum~~~', +receiptPaymentListSum, payAmount);
- if(Math.abs(+receiptPaymentListSum - payAmount) > 0.01){
- this.$message.error('计划收款金额合计与优惠后金额不一致');
- return;
- }
- }
-
- if (isTemporary.length > 0) {
- this.$message.error(
- isTemporary.toString() +
- '是临时产品,无法创建订单,请先去主数据维护!'
- );
- return;
- }
- this.interfaceCall(commitData, type);
- } catch (error) {
- console.log(error);
- // 表单验证未通过,不执行保存操作
- }
- },
- interfaceCall(commitData, type) {
- let API = this.isUpdate ? UpdateInformation : addInformation;
- API(commitData)
- .then((res) => {
- this.loading = false;
- if(this.form.partaId) {
- updateRelationStatus([this.form.partaId]);
- }
- if (this.form.contractId) {
- updateContractStatus([this.form.contractId]);
- }
- if (type === 'sub') {
- this.saleOrderSubmitOrGenerate(res, commitData);
- return;
- } else {
- this.$message.success('操作成功');
- }
- this.cancel();
- this.$emit('done');
- })
- .catch((e) => {
- //this.loading = false;
- });
- },
- async callBack() {
- if (!this.current.generatePurchase && !this.current.generateProduce) {
- return 0;
- }
- const code = saveOrderBomList({
- categoryDTOList: this.tableList || [],
- orderId: this.current.id
- });
- return code;
- },
- async saleOrderSubmitOrGenerate(id) {
- this.tableList = [];
- this.current = await getSaleOrderDetail(this.businessId || id);
- if (!this.current.generatePurchase && !this.current.generateProduce) {
- this.saleOrderSubmit(this.current.id);
- } else {
- const data = await getByRepeatBomAttribute(this.current.id);
- if (data && data.length) {
- this.$refs.bomDialogRef.open(data);
- return;
- }
- this.saleOrderSubmit(this.current.id);
- }
- },
- bomDialogSuccess(tableList) {
- this.tableList = tableList;
- this.saleOrderSubmit(this.current.id);
- },
- async saleOrderSubmit(res) {
- const data = await getSaleOrderDetail(this.businessId || res);
- this.processSubmitDialogFlag = true;
- let businessType =
- data.needProduce == 1
- ? '有客户生产性订单'
- : data.needProduce == 2
- ? '无客户生产性订单'
- : data.needProduce == 4
- ? '不定向订单'
- : '库存式订单';
- this.$nextTick(() => {
- let params = {
- businessId: data.id,
- businessKey: 'sales_order_approve',
- formCreateUserId: data.createUserId,
- variables: {
- businessCode: data.orderNo,
- businessName: data.partaName,
- businessType: businessType
- }
- };
- this.$refs.processSubmitDialogRef.init(params);
- });
- },
- reload() {
- this.cancel();
- this.$emit('done');
- },
- cancel() {
- this.$nextTick(() => {
- // 关闭后,销毁所有的表单数据
- this.$refs['otherForm'] && this.$refs['otherForm'].resetFields();
- this.$refs['formRef'] && this.$refs['formRef'].resetFields();
- this.$store.commit('order/clearUserData');
- this.form = copyObj(this.formDef);
- this.visible = false;
- this.projectData = {};
- });
- },
- //查找合同分类对应name
- findNameById(tree, targetId) {
- for (let i = 0; i < tree.length; i++) {
- const node = tree[i];
- if (node.id === targetId) {
- return node.name;
- }
- if (node.children && node.children.length > 0) {
- const name = this.findNameById(node.children, targetId);
- if (name) {
- return name;
- }
- }
- }
- return null;
- },
- // 日期范围变化
- settlementDateChange(val) {
- // console.log(val);
- let dateRange = [];
- if(this.form.settlementMode == 1) {
- // // this.transformDays(val)
- dateRange = this.transformDaysFun(val);
- }
- if(this.form.settlementMode == 2) {
- // // this.transformMonth(val)
- dateRange = this.transformMonthFun(val);
- }
- // console.log('dateRange~~~', dateRange);
- this.$set(this.form, 'issueNumber', dateRange.length);
- // this.setDefaultList(dateRange)
- this.$refs.paymentCollectionPlanRef.defaultList(this.form.settlementMode, this.form.issueNumber, dateRange);
- },
- // 收款日变化
- receiptDateChange(v) {
- // this.transformMonth(this.form.settlementDate)
- if(this.form.settlementDate.length > 0 && this.form.issueNumber) {
- const dateRange = this.transformMonthFun(this.form.settlementDate, v);
- this.$refs.paymentCollectionPlanRef.defaultList(this.form.settlementMode, this.form.issueNumber, dateRange);
- }
- },
- // 期数变化
- issueNumberChange(v) {
- let dateRange = [];
- if(this.form.settlementMode == 1) {
- dateRange = this.transformDaysFun(this.form.settlementDate, v);
- this.$refs.paymentCollectionPlanRef.defaultList(this.form.settlementMode, v, dateRange);
- } else if(this.form.settlementMode == 2) {
- dateRange = this.transformMonthFun(this.form.settlementDate, v);
- this.$refs.paymentCollectionPlanRef.defaultList(this.form.settlementMode, v, dateRange);
- } else {
- this.$refs.paymentCollectionPlanRef.defaultList(this.form.settlementMode, v);
- }
- },
- transformDaysFun(date) {
- const startDate = new Date(date[0]);
- const endDate = new Date(date[1]);
- // 计算毫秒差并转换为天数,使用Math.ceil确保结果为整数
- const days = Math.ceil((endDate - startDate) / (1000 * 60 * 60 * 24)) + 1;
- console.log('包含两头的天数:', days);
- // 生成包括头尾在内的所有日期
- const allDates = [];
- const current = new Date(startDate);
-
- // 遍历从开始日期到结束日期的所有天数
- while (current <= endDate) {
- // 格式化日期为YYYY-MM-dd
- const year = current.getFullYear();
- const month = current.getMonth() + 1; // 月份从0开始,需要+1
- const day = current.getDate();
-
- const formattedMonth = String(month).padStart(2, '0');
- const formattedDay = String(day).padStart(2, '0');
- const formattedDateStr = `${year}-${formattedMonth}-${formattedDay}`;
-
- allDates.push(formattedDateStr);
-
- // 移动到下一天
- current.setDate(current.getDate() + 1);
- }
- return allDates;
- },
- transformMonthFun(date, day) {
- // 处理月份数据(转换为Date对象)
- const parseMonthDate = (dateStr) => {
- return dateStr instanceof Date ? dateStr : new Date(dateStr + '-01');
- };
-
- const start = parseMonthDate(date[0]);
- const end = parseMonthDate(date[1]);
-
- // 先生成所有月份的日期数组
- const allMonthDates = [];
- const currentDate = new Date(start);
-
- // 遍历从开始月份到结束月份的所有月份
- while (currentDate <= end) {
- const year = currentDate.getFullYear();
- const month = currentDate.getMonth() + 1; // 月份从0开始,需要+1
- const receiptDate = day;
-
- // 格式化日期为YYYY-MM-dd
- const formattedMonth = String(month).padStart(2, '0');
- const formattedDate = String(receiptDate).padStart(2, '0');
- const deadLine = receiptDate ? `${year}-${formattedMonth}-${formattedDate}` : '';
-
- allMonthDates.push(deadLine);
-
- // 使用Date对象的setMonth方法正确移动到下一个月(自动处理年份变化)
- currentDate.setMonth(currentDate.getMonth() + 1);
- }
- return allMonthDates;
- },
- }
- };
- </script>
- <style scoped lang="scss">
- .TotalAmount {
- font-size: 16px;
- padding-right: 30px;
- }
- .totalPlanNum {
- :deep(.el-input-group__append) {
- width: 160px;
- }
- }
- </style>
|