12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046 |
- <template>
- <div class="requisition_add">
- <el-tabs type="border-card" v-model="tabValue" @tab-click="handleClick">
- <el-tab-pane label="基本信息" name="first">
- <div style="width: 100%;height: 680px;overflow-y: auto; overflow-x: hidden;">
- <el-form :model="basicForm" :rules="basicRules" ref="basic" label-width="160px">
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="单据编码" prop="billCode">
- <el-input disabled v-model="basicForm.billCode"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="申请组织" prop="orgId">
- <el-input disabled v-model="basicForm.orgId"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="四级分类" prop="classifyId">
- <el-select
- ref="fourTag"
- v-model="basicForm.classifyId"
- placeholder="四级分类"
- :disabled="disable"
- @focus="chooseFourClass"
- >
- <el-option
- v-for="item in testOptions"
- :key="item.id"
- :label="item.materialType"
- :value="item.id"
- />
- </el-select>
- <!-- <el-input :disabled="disable" v-model="basicForm.classifyId">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="chooseFourClass"></el-button>
- </el-input> -->
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="医药物料" prop="isMedicine">
- <el-select
- v-model="basicForm.isMedicine"
- placeholder="医药物料"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="DI" prop="diCode">
- <el-input :disabled="disable" v-model="basicForm.diCode"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="物料名称" prop="name">
- <el-input :disabled="disable" v-model="basicForm.name"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="英文名称" prop="enName">
- <el-input :disabled="disable" v-model="basicForm.enName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="简称" prop="commonName">
- <el-input :disabled="disable" v-model="basicForm.commonName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="规格" prop="specification">
- <el-input :disabled="disable" v-model="basicForm.specification"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="型号" prop="model">
- <el-input :disabled="disable" v-model="basicForm.model"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="计量单位" prop="unitId">
- <el-input :disabled="disable" v-model="basicForm.unitId">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test02"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="生产厂家/代理人" prop="manufacturerId">
- <el-input :disabled="disable" v-model="basicForm.manufacturerId">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test02"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="注册人/上市许可持有人" prop="registrant">
- <el-input :disabled="disable" v-model="basicForm.registrant"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="产地" prop="originPlace">
- <el-input :disabled="disable" v-model="basicForm.originPlace">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test02"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="厂家物料名称" prop="manufacturersMaterialName">
- <el-input :disabled="disable" v-model="basicForm.manufacturersMaterialName"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="B2C物料" prop="isB2c">
- <el-select
- v-model="basicForm.medicineMaterial"
- placeholder="B2C物料"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="成套件" prop="assembly">
- <el-select
- v-model="basicForm.assembly"
- placeholder="成套件"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="批号及库存状态管理" prop="isInventoryStatus">
- <el-select
- v-model="basicForm.isInventoryStatus"
- placeholder="批号及库存状态管理"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="效期管理" prop="expiryDateManagerment">
- <el-select
- v-model="basicForm.expiryDateManagerment"
- placeholder="效期管理"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="近效期管理" prop="nearOnsetManagerment">
- <el-select
- v-model="basicForm.nearOnsetManagerment"
- placeholder="近效期管理"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="有效期" prop="usefulLife">
- <el-select
- v-model="basicForm.usefulLife"
- placeholder="有效期"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="有效期单位" prop="expiryUnitId">
- <el-select
- v-model="basicForm.expiryUnitId"
- placeholder="有效期单位"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="有效期至单位" prop="usefulLifeUnitId">
- <el-select
- v-model="basicForm.usefulLifeUnitId"
- placeholder="有效期至单位"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in options"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="近效期预警天数" prop="recentWarningPeriod">
- <el-input :disabled="disable" v-model="basicForm.recentWarningPeriod"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="存储条件" prop="storageCondition">
- <el-select
- v-model="basicForm.storageCondition"
- placeholder="存储条件"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in dict.type.sys_storage_condition"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="运输条件" prop="transportationCondition">
- <el-select
- v-model="basicForm.transportationCondition"
- placeholder="运输条件"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="item in dict.type.sys_conditions_carriage"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="物料税类" prop="materialRate">
- <el-input :disabled="disable" v-model="basicForm.materialRate">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test02"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="交货周期" prop="deliveryPeriod">
- <el-input :disabled="disable" v-model="basicForm.deliveryPeriod"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="最小起定量" prop="minOrderQty">
- <el-input :disabled="disable" v-model="basicForm.minOrderQty"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="最小包装量" prop="minPackQty">
- <el-input :disabled="disable" v-model="basicForm.minPackQty"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="采购员" prop="puPersonnelId">
- <el-input :disabled="disable" v-model="basicForm.puPersonnelId">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test02"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="最小批量" prop="minBatchQty">
- <el-input :disabled="disable" v-model="basicForm.minBatchQty"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="长度(MM)" prop="length">
- <el-input :disabled="disable" v-model="basicForm.length"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="高度(MM)" prop="height">
- <el-input :disabled="disable" v-model="basicForm.height"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="宽度(MM)" prop="width">
- <el-input :disabled="disable" v-model="basicForm.width"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="箱包装数" prop="boxPackaingQty">
- <el-input :disabled="disable" v-model="basicForm.boxPackaingQty"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="中包装数" prop="mediumPackageQty">
- <el-input :disabled="disable" v-model="basicForm.mediumPackageQty"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="包装说明" prop="packExplain">
- <el-input :disabled="disable" v-model="basicForm.packExplain"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="业务线" prop="businessLine">
- <el-input :disabled="disable" v-model="basicForm.businessLine">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test02"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="物料申请人" prop="proposerId">
- <el-input :disabled="disable" v-model="basicForm.proposerId"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="条形码" prop="barCode">
- <el-input :disabled="disable" v-model="basicForm.barCode"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="使用期限/次数" prop="serviceLife">
- <el-input :disabled="disable" v-model="basicForm.serviceLife"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="医保代码" prop="healthCode">
- <el-input :disabled="disable" v-model="basicForm.healthCode"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="原型系统物料编码" prop="oriMaterialCode">
- <el-input :disabled="disable" v-model="basicForm.oriMaterialCode"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="生产许可证/经营许可证/备案号" prop="productionPermit">
- <el-input :disabled="disable" v-model="basicForm.productionPermit"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="一级分类" prop="oneClass">
- <el-input disabled v-model="basicForm.oneClass"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="二级分类" prop="twoClass">
- <el-input disabled v-model="basicForm.twoClass"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="三级分类" prop="threeClass">
- <el-input disabled v-model="basicForm.threeClass"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="启用状态" prop="isEnable">
- <el-input disabled v-model="basicForm.isEnable"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="备注" prop="remark">
- <el-input :disabled="disable" v-model="basicForm.remark"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- </div>
- </el-tab-pane>
- <el-tab-pane label="医药属性" name="second">
- <el-form :model="basicForm2" ref="basic2" label-width="160px">
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="药品" prop="isDrug">
- <el-select
- v-model="basicForm2.isDrug"
- placeholder="药品"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="dict in dict.type.sys_medicine"
- :key="dict.value"
- :label="dict.label"
- :value="dict.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="注册证号/备案凭证编号" prop="registrationNo">
- <el-input :disabled="disable" v-model="basicForm2.registrationNo"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="医疗器械" prop="medicalInstruments">
- <el-select
- v-model="basicForm2.medicalInstruments"
- placeholder="医疗器械"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="dict in dict.type.medical_instruments"
- :key="dict.value"
- :label="dict.label"
- :value="dict.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="通用名称" prop="commonName">
- <el-input :disabled="disable" v-model="basicForm2.commonName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="批准文号" prop="ratifyBatchNo">
- <el-input :disabled="disable" v-model="basicForm2.ratifyBatchNo"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="剂型" prop="dosageFrom">
- <el-input :disabled="disable" v-model="basicForm2.dosageFrom">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test02"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="旧注册证号" prop="oriRegistrationNo">
- <el-input :disabled="disable" v-model="basicForm2.oriRegistrationNo"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="养护类型" prop="curingType">
- <el-select
- v-model="basicForm2.curingType"
- placeholder="养护类型"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="dict in dict.type.curing_type"
- :key="dict.value"
- :label="dict.label"
- :value="dict.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- <!-- <el-row style="margin-bottom: 12px;">
- <span>物料类别</span>
- </el-row>
- <el-row style="margin-bottom: 12px;">
- <el-button type="primary" size="small" plain @click="addLine">新增</el-button>
- <el-button type="primary" size="small" plain @click="handleDelete">删除</el-button>
- <el-button type="primary" size="small" plain @click="testsave">暂存</el-button>
- </el-row> -->
- <!-- <el-row>
- <el-col :span="12">
- <el-table
- :data="basicForm2.medicineTypeChanges"
- class="request-table"
- @selection-change="handleSelectionChange"
- >
- <el-table-column type="selection" width="55" />
- <el-table-column label="序号" align="center" prop="sort">
- <template slot-scope="scope">
- <el-input v-model="scope.row.sort"></el-input>
- </template>
- </el-table-column>
- <el-table-column label="物料类别" align="center" prop="medicineCode">
- <template slot-scope="scope">
- <el-input v-model="scope.row.medicineCode"></el-input>
- </template>
- </el-table-column>
- <el-table-column label="类别名称" align="center" prop="medicineName">
- <template slot-scope="scope">
- <el-input v-model="scope.row.medicineName"></el-input>
- </template>
- </el-table-column>
- </el-table>
- </el-col>
- </el-row> -->
- </el-tab-pane>
- <!-- <el-tab-pane label="修改记录" name="third">
- <el-table
- :data="basicForm.changeRecords"
- class="request-table"
- >
- <el-table-column label="字段名称" align="center" prop="pageCondtion" />
- <el-table-column label="变更前" align="center" prop="beforeChangeValue" />
- <el-table-column label="变更后" align="center" prop="afterChangeValue" />
- </el-table>
- </el-tab-pane> -->
- <el-tab-pane label="单据信息" name="fourth">
- <el-form :model="basicForm" ref="info" label-width="160px">
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="申请人" prop="createBy">
- <el-input disabled v-model="basicForm.createBy"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="申请时间" prop="applicationTime">
- <el-input disabled v-model="basicForm.applicationTime"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="创建人" prop="createByName">
- <el-input disabled v-model="basicForm.createByName"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="创建时间" prop="createTime">
- <el-input disabled v-model="basicForm.createTime"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="最后修改人" prop="updateByName">
- <el-input disabled v-model="basicForm.updateByName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="最后修改时间" prop="updateTime">
- <el-input disabled v-model="basicForm.updateTime"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="最后审核人" prop="reviewedByName">
- <el-input disabled v-model="basicForm.reviewedByName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="最后审核时间" prop="approvalTime">
- <el-input disabled v-model="basicForm.approvalTime"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="单据状态" prop="status">
- <el-input disabled v-model="basicForm.status"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- </el-tab-pane>
- </el-tabs>
- <div class="btn_group">
- <el-col :span="1.5">
- <el-button type="primary" size="small" plain @click="save" v-if="pageStu == 'add' || pageStu == 'edit'">保存</el-button>
- </el-col>
- <el-col :span="1.5" style="margin: 0 10px;">
- <el-button type="primary" size="small" plain @click="submit" v-if="pageStu == 'add' || pageStu == 'edit'">提交</el-button>
- </el-col>
- <el-col :span="1.5">
- <el-button type="primary" size="small" plain @click="back">返回</el-button>
- </el-col>
- </div>
- <popDialog
- ref="contractSelect"
- @doSubmit="selectionsToInput"
- :selectData="selectData"
- :single="true"
- />
- <factory
- ref="contractSelect2"
- @doSubmit="selectionsToInput2"
- :selectData="selectData2"
- :single="true"
- />
- <fourClass
- ref="fourClass"
- @doSubmit="acceptFourClass"
- :selectData="selectData3"
- :single="true"
- />
- </div>
- </template>
- <script>
- import popDialog from '@/components/PopDialog/index.vue'
- import factory from '@/components/PopDialog/productFactory.vue'
- import fourClass from '@/components/PopDialog/fourClass.vue'
- import { addReq, getReqDetail, editReq } from '@/api/requisition/basic'
- // 调用物料分类详情接口用于数据回显
- import { getDetail } from '@/api/classify/basic';
- export default {
- name: 'requisition_add',
- dicts: ['sys_storage_condition', 'sys_conditions_carriage', 'sys_medicine', 'medical_instruments', 'curing_type'],
- components: {
- popDialog,
- factory,
- fourClass
- },
- props: ['pageStu', 'row', 'disable'],
- model: {
- prop: 'isList',
- event: 'jugislist'
- },
- data() {
- return{
- testOptions: [],
- tabValue: 'first',
- basicForm: {
- billCode: '',
- orgId: '',
- // 四级分类/物料分类
- classifyId: '',
- // 是否医药物料
- isMedicine: '',
- // DI
- diCode: '',
- // 物料名称
- name: '',
- // 英文名称
- enName: '',
- commonName: '',
- specification: '',
- model: '',
- unitId: '',
- manufacturerId: '',
- registrant: '',
- originPlace: '',
- manufacturersMaterialName: '',
- isB2c: '',
- assembly: '',
- isInventoryStatus: '',
- expiryDateManagerment: '',
- nearOnsetManagerment: '',
- usefulLife: '',
- expiryUnitId: '',
- usefulLifeUnitId: '',
- recentWarningPeriod: '',
- storageCondition: '',
- transportationCondition: '',
- materialRate: '',
- deliveryPeriod: '',
- minOrderQty: '',
- minPackQty: '',
- puPersonnelId: '',
- minBatchQty: '',
- length: '',
- height: '',
- width: '',
- boxPackaingQty: '',
- mediumPackageQty: '',
- packExplain: '',
- businessLine: '',
- proposerId: '',
- barCode: '',
- serviceLife: '',
- healthCode: '',
- oriMaterialCode: '',
- productionPermit: '',
- oneClass: '',
- twoClass: '',
- threeClass: '',
- isEnable: '',
- remark: '',
- // 物料申请单-单据信息
- applyBillInfo: {
- createByName: '',
- createTime:'',
- updateByName: '',
- updateTime: '',
- reviewedByName: '',
- auditTime: ''
- },
- // 单据信息字段
- status: ''
- },
- options: [{
- value: '0',
- label: '是'
- },{
- value: '2',
- label: '否'
- }],
- basicRules: {},
- basicForm2: {
- // 是否药品
- isDrug: '',
- registrationNo: '',
- medicalInstruments: '',
- commonName: '',
- ratifyBatchNo: '',
- dosageFrom: '',
- oriRegistrationNo: '',
- curingType: '',
- // 医药属性子表
- // medicineTypeChanges:[
- // ],
- },
- // tableList: [],
- // 子表选中
- ids: [],
- // 弹窗
- name: '',
- selectData: [],
- selectData2: [],
- selectData3: [],
- }
- },
- // watch: {
- // value: {
- // handler (newVal) {
- // this.selectData = []
- // if (newVal) {
- // newVal.split(',').forEach((id) => { // 回显拿数据
- // this.contractService.queryById(id).then(({data}) => {
- // if (data && data.id !== '') {
- // this.selectData.push(data)
- // }
- // })
- // })
- // }
- // },
- // immediate: true,
- // deep: false
- // },
- // selectData: {
- // handler (newVal) {
- // this.name = newVal.map(contract => contract.contractName).join(',')
- // },
- // immediate: false,
- // deep: false
- // }
- // },
- mounted() {
- this.$nextTick(() => {
- // console.log('页面状态',this.pageStu)
- if(this.pageStu == 'check') {
- // alert('详情页面:')
- console.log('页面状态',this.pageStu)
- console.log('数据', this.row)
- this.getDetails(this.row)
- // 获取树形详情
- this.getTreeDetails(this.row.classifyId)
- } else if (this.pageStu == 'edit') {
- // alert('修改页面')
- console.log('页面状态',this.pageStu)
- console.log('数据', this.row)
- this.getDetails(this.row)
- // 获取树形详情
- this.getTreeDetails(this.row.classifyId)
- } else if(this.pageStu == 'add') {
- // alert('新增页面')
- console.log('页面状态',this.pageStu)
- }
- })
- },
- methods: {
- handleClick(tab, event) {
- console.log(tab, event);
- console.log('页面状态',this.pageStu)
- },
- // 用于回显四级分类树形选择
- getTreeDetails(id) {
- getDetail(id).then(res => {
- if (res.code === 200) {
- this.testOptions.push(res.data)
- this.basicForm.oneClass = res.data.oneClass
- this.basicForm.twoClass = res.data.twoClass
- this.basicForm.threeClass = res.data.threeClass
- }
- })
- },
- // 如果是详情进入,则调用详情接口
- getDetails(row) {
- getReqDetail(row.id).then(res => {
- console.log('res',res)
- if(res.code === 200) {
- this.basicForm = res.data
- if(res.data.sysMaterialMedcineApply) {
- this.basicForm2 = res.data.sysMaterialMedcineApply
- }
- }
- })
- },
- save() {
- if(this.pageStu == 'edit') {
- let sparams = {...this.basicForm, ...{status: 0}}
- sparams.sysMaterialMedcineApply = this.basicForm2
- console.log('提交参数', sparams)
- editReq(sparams).then(res => {
- if(res.code === 200) {
- this.$message({
- message: res.msg,
- type: 'success'
- });
- this.back()
- }
- })
- } else {
- // alert('保存传status:0')
- let sparams = {...this.basicForm, ...{status: 0}}
- sparams.sysMaterialMedcineApply = this.basicForm2
- console.log('保存参数', sparams)
- addReq(sparams).then(res => {
- if(res.code === 200) {
- this.$message({
- message: res.msg,
- type: 'success'
- });
- this.back()
- }
- })
- }
- },
- submit() {
- // alert('提交传status:1')
- let sparams = {...this.basicForm, ...{status: 1}}
- sparams.sysMaterialMedcineApply = this.basicForm2
- console.log('提交参数', sparams)
- editReq(sparams).then(res => {
- if(res.code === 200) {
- this.$message({
- message: res.msg,
- type: 'success'
- });
- this.back()
- }
- })
- },
- back() {
- this.$emit('jugislist', true)
- let queryParams = {
- pageNum: 1,
- pageSize: 10
- }
- this.$emit('refresh', queryParams)
- },
- // 子表增删行
- // handleSelectionChange(val) {
- // this.ids = val
- // console.log('this.ids',this.ids)
- // },
- // addLine() {
- // //添加行数
- // let newValue = {
- // sort:'',
- // medicineCode: '',
- // medicineName: '',
- // };
- // this.basicForm2.medicineTypeChanges.push(newValue);
- // },
- // handleDelete(index) {
- // if(this.ids.length == 0) {
- // this.$message({
- // message: '请选择删除条目',
- // type: 'warning'
- // });
- // } else {
- // // console.log('index',index)
- // // this.basicForm2.medicineTypeChanges.splice(index, 1);
- // this.basicForm2.medicineTypeChanges = this.basicForm2.medicineTypeChanges.filter(item =>
- // !this.ids.some(ele =>
- // ele.sort == item.sort))
- // }
- // },
- // testsave() {
- // console.log('暂存表格:', this.basicForm2.medicineTypeChanges)
- // console.log('暂存表单1', this.basicForm)
- // let params = {...this.basicForm, ...this.basicForm2}
- // console.log('暂存总表单', params)
- // },
- // 设置选中
- selectionsToInput (selections) {
- console.log('父组件拿到的:', selections)
- this.selectData = selections
- this.$emit('getInfo', this.selectData)
- getMaterialDetails(selections[0].id).then(res => {
- console.log('res',res)
- if (res.code === 200) {
- let data = res.data.data
- // 物料id
- this.basicForm.materialId = data.id
- // 物料分类Id
- this.basicForm.materialClassifyId = data.classifyId
- this.basicForm.materialCode = data.code
- this.basicForm.materialName = data.name
- this.basicForm.medicineMaterial = data.isMedicine
- this.basicForm.oneClass = data.oneClass
- this.basicForm.twoClass = data.twoClass
- this.basicForm.threeClass = data.threeClass
- this.basicForm.fourClass = data.fourClass
- this.basicForm.specification = data.specification
- this.basicForm.model = data.model
- this.basicForm.registrant = data.registrant
- this.basicForm.storageConditions = data.storageCondition
- this.basicForm.transportCondition = data.transportationCondition
- this.basicForm.remark = data.deliveryPeriod
- if(data.medcines.length !== 0) {
- this.basicForm2.drug = data.medcines[0].isDrug
- this.basicForm2.registrationNo = data.medcines[0].registrationNo
- this.basicForm2.medicalDevices = data.medcines[0].medicalInstruments
- this.basicForm2.maintenanceType = data.medcines[0].curingType
- }
- }
- })
- },
- selectionsToInput2 (selections) {
- console.log('选择的数据',selections)
- this.basicForm.manufacturerId = selections[0].code
- },
- acceptFourClass (selections) {
- console.log('父组件收到的数据',selections)
- this.testOptions.push(selections)
- console.log('收到的数据转成数组', this.testOptions)
- this.basicForm.classifyId = selections.id
- this.getTreeDetails(selections.id)
- },
- chooseFourClass() {
- console.log('1111')
- this.$refs.fourTag.blur()
- this.$refs.fourClass.init()
- },
- // 显示列表
- test01() {
- console.log('测试点击')
- this.$refs.contractSelect.init()
- },
- test02() {
- console.log('测试弹窗2');
- this.$refs.contractSelect2.init()
- }
- }
- }
- </script>
- <style lang="scss" scoped>
- .requisition_add {
- height: calc(100vh - 84px);
- padding: 12px;
- box-sizing: border-box;
- }
- .btn_group {
- width: 100%;
- margin: 20px 0;
- display: flex;
- justify-content: center;
- }
- </style>
|