123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703 |
- <template>
- <div class="apply_add">
- <el-tabs type="border-card" v-model="tabValue" @tab-click="handleClick">
- <el-tab-pane label="基本信息" name="first">
- <el-form :model="basicForm" :rules="basicRules" ref="basic" label-width="170px">
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="单据编码" prop="code">
- <el-input disabled v-model="basicForm.code"></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="materialCode">
- <el-input :disabled="disable" v-model="basicForm.materialCode">
- <el-button :disabled="disable" slot="append" icon="el-icon-more" @click="test01"></el-button>
- </el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="物料名称" prop="materialName">
- <el-input :disabled="disable" v-model="basicForm.materialName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="医药物料" prop="medicineMaterial">
- <el-select
- v-model="basicForm.medicineMaterial"
- 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="oneClass">
- <el-input :disabled="disable" v-model="basicForm.oneClass"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="8">
- <el-form-item label="二级分类" prop="twoClass">
- <el-input :disabled="disable" v-model="basicForm.twoClass"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="三级分类" prop="threeClass">
- <el-input :disabled="disable" v-model="basicForm.threeClass"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="8">
- <el-form-item label="四级分类" prop="fourClass">
- <el-input :disabled="disable" v-model="basicForm.fourClass"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <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-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="factory">
- <el-select
- ref="factoryOrman"
- v-model="basicForm.factory"
- placeholder="生产厂家/代理人"
- clearable
- :disabled="disable"
- @focus="chooseFactory"
- >
- <el-option
- v-for="item in factoryOptions"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- />
- </el-select>
- <!-- <el-input :disabled="disable" v-model="basicForm.factory">
- <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="storageConditions">
- <el-select
- v-model="basicForm.storageConditions"
- placeholder="存储条件"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="dict in dict.type.sys_storage_condition"
- :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="transportCondition">
- <el-select
- v-model="basicForm.transportCondition"
- placeholder="运输条件"
- clearable
- :disabled="disable"
- >
- <el-option
- v-for="dict in dict.type.sys_conditions_carriage"
- :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="leadTime">
- <el-input type="number" :disabled="disable" v-model="basicForm.leadTime"></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>
- </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="drug">
- <el-select
- v-model="basicForm2.drug"
- 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="medicalDevices">
- <el-select
- v-model="basicForm2.medicalDevices"
- 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="maintenanceType">
- <el-select
- v-model="basicForm2.maintenanceType"
- 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="createByName">
- <el-input disabled v-model="basicForm.createByName"></el-input>
- </el-form-item>
- </el-col>
- <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="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="approver">
- <el-input disabled v-model="basicForm.approver"></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-select
- v-model="basicForm.status"
- size="small"
- disabled
- >
- <el-option
- v-for="item in statusOptions"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- <!-- <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 == '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="factory"
- @doSubmit="acceptFactory"
- :selectData="selectData2"
- :single="true"
- />
- </div>
- </template>
- <script>
- import popDialog from '@/components/PopDialog/index.vue'
- import factory from '@/components/PopDialog/productFactory.vue'
- import { addChangeList, getMaterialDetails, getChangeDetails, editChangeList } from '@/api/changeApply/basic'
- // 生产厂商/代理人调用用于回显
- import { getProductFactory } from '@/api/changeApply/basic'
- export default {
- name: 'applyAdd',
- dicts: ['sys_storage_condition', 'sys_conditions_carriage', 'sys_medicine', 'medical_instruments', 'curing_type'],
- components: {
- popDialog,
- factory
- },
- props: ['pageStu', 'row', 'disable'],
- model: {
- prop: 'isList',
- event: 'jugislist'
- },
- data() {
- return{
- factoryOptions: [],
- tabValue: 'first',
- basicForm: {
- code: '',
- orgId: '',
- // 物料id
- materialId:'',
- materialCode: '',
- materialName: '',
- medicineMaterial: '',
- oneClass: '',
- twoClass: '',
- threeClass: '',
- fourClass: '',
- specification: '',
- model: '',
- factory: '',
- registrant: '',
- storageConditions: '',
- transportCondition: '',
- leadTime: '',
- remark: '',
- // 修改记录
- changeRecords: [],
- // 单据信息字段
- createBy: '',
- applicationTime: '',
- createTime:'',
- updateBy: '',
- updateTime: '',
- approver: '',
- approvalTime: '',
- status: ''
- },
- options: [{
- value: '0',
- label: '是'
- },{
- value: '2',
- label: '否'
- }],
- statusOptions: [{
- value: 0, label: '未提交'
- },{
- value: 1, label: '审批中'
- },{
- value: 2, label: '已完成'
- },{
- value: 3, label: '已驳回'
- },],
- basicRules: {
- materialCode: [{ required: true, message: '请选择物料编码', trigger: 'blur' }],
- materialName: [{required: true, message: '请填写物料名称', trigger: 'blur'}],
- oneClass: [{required: true, message: '请填写一级分类', trigger: 'blur'}],
- twoClass: [{required: true, message: '请填写二级分类', trigger: 'blur'}],
- threeClass: [{required: true, message: '请填写三级分类', trigger: 'blur'}],
- fourClass: [{required: true, message: '请填写四级分类', trigger: 'blur'}],
- specification: [{required: true, message: '请填写四级分类', trigger: 'blur'}],
- model: [{required: true, message: '请填写四级分类', trigger: 'blur'}],
- factory: [{required: true, message: '请选择生产厂家/代理人', trigger: 'blur'}],
- registrant: [{required: true, message: '请填写注册人/上市许可持有人', trigger: 'blur'}],
- storageConditions: [{required: true, message: '请选择存储条件', trigger: 'blur'}],
- transportCondition: [{required: true, message: '请选择运输条件', trigger: 'blur'}],
- leadTime: [{required: true, message: '请填写交货周期', trigger: 'blur'}],
- },
- basicForm2: {
- drug: '',
- registrationNo: '',
- medicalDevices: '',
- maintenanceType: '',
- // 医药属性子表
- // medicineTypeChanges:[
- // ],
- },
- // tableList: [],
- // 子表选中
- ids: [],
- // 弹窗
- name: '',
- selectData: [],
- selectData2: []
- }
- },
- // 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)
- // 生产厂家代理人用于回显
- if (this.row.factory) {
- this.getFactoryDetails(this.row.factory)
- }
- } else if (this.pageStu == 'edit') {
- // alert('修改页面')
- console.log('页面状态',this.pageStu)
- console.log('数据', this.row)
- this.getDetails(this.row)
- // 生产厂家代理人用于回显
- if (this.row.factory) {
- this.getFactoryDetails(this.row.factory)
- }
- } else if(this.pageStu == 'add') {
- // alert('新增页面')
- console.log('页面状态',this.pageStu)
- }
- })
- },
- methods: {
- // 生产厂家/代理人用于回显
- getFactoryDetails(id) {
- getProductFactory({id:id}).then(res => {
- if(res.code === 200) {
- this.factoryOptions = res.data.tableBody
- }
- })
- },
- handleClick(tab, event) {
- console.log(tab, event);
- console.log('页面状态',this.pageStu)
- },
- // 如果是详情进入,则调用详情接口
- getDetails(row) {
- getChangeDetails(row.id).then(res => {
- if(res.code === 200) {
- this.basicForm = res.data
- if (res.data.medicineChange) {
- this.basicForm2 = res.data.medicineChange
- }
- }
- })
- },
- save() {
- // alert('保存传status:0')
- let sparams = {...this.basicForm, ...{status: 0}}
- sparams.medicineChange = this.basicForm2
- console.log('保存参数', sparams)
- this.$refs['basic'].validate((valid) => {
- if (valid) {
- addChangeList(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.medicineChange = this.basicForm2
- console.log('提交参数', sparams)
- this.$refs['basic'].validate((valid) => {
- if(valid) {
- editChangeList(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.leadTime = 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.factory = selections[0].manufactureName
- // },
- // 显示列表
- test01() {
- console.log('测试点击')
- this.$refs.contractSelect.init()
- },
- // test02() {
- // console.log('测试弹窗2');
- // this.$refs.contractSelect2.init()
- // },
- // 选择生产厂家/代理人
- acceptFactory (selections) {
- console.log('选择的数据',selections)
- this.factoryOptions = selections
- this.basicForm.factory = selections[0].id
- this.getFactoryDetails(selections[0].id)
- },
- // 生产厂家/代理人显示列表
- chooseFactory() {
- this.$refs.factoryOrman.blur()
- this.$refs.factory.init()
- },
- }
- }
- </script>
- <style lang="scss" scoped>
- .apply_add {
- height: calc(100vh - 84px);
- padding: 12px;
- box-sizing: border-box;
- }
- .btn_group {
- width: 100%;
- margin: 20px 0;
- display: flex;
- justify-content: center;
- }
- </style>
|