fix: 新功能开发完善。
This commit is contained in:
524
src/pages/health/medicineBasic/addEdit.vue
Normal file
524
src/pages/health/medicineBasic/addEdit.vue
Normal file
@@ -0,0 +1,524 @@
|
||||
<template>
|
||||
<view class="container" style="paddingBottom:1rpx;">
|
||||
<u-navbar
|
||||
leftIconSize="40rpx"
|
||||
leftIconColor="#333333"
|
||||
title="药品基础信息"
|
||||
>
|
||||
</u-navbar>
|
||||
<view class="section">
|
||||
<view class="section-title">{{ title}}</view>
|
||||
<view class="form-view">
|
||||
<u--form labelPosition="left" :model="form" :rules="rules" ref="uForm" label-width="auto"
|
||||
:labelStyle="{ color: '#333333', fontSize: '30rpx' }">
|
||||
<u-form-item label="药品全称" prop="name" required >
|
||||
<u--input v-model="form.name" placeholder="请填写药品全称"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="药品简称" prop="shortName" required >
|
||||
<u--input v-model="form.shortName" placeholder="请填写药品简称"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="药品编码" prop="code" required >
|
||||
<u--input v-model="form.code" placeholder="请填写药品编码"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
|
||||
<u-form-item label="药品剂型" prop="dosageFormName" required @click="handleDosageForm">
|
||||
<u--input v-model="form.dosageFormName" disabled disabledColor="#ffffff" placeholder="请选择药品剂型"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="治疗类型" prop="treatmentTypeName" required @click="handleTreatmentType">
|
||||
<u--input v-model="form.treatmentTypeName" disabled disabledColor="#ffffff" placeholder="请选择治疗类型"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="药品分类" prop="classificationName" required @click="handleClassification">
|
||||
<u--input v-model="form.classificationName" disabled disabledColor="#ffffff" placeholder="请选择药品分类"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
|
||||
<u-form-item label="类别" prop="categoryName" required @click="handleCategory">
|
||||
<u--input v-model="form.categoryName" disabled disabledColor="#ffffff" placeholder="请选择类别"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="品牌" prop="brand" required >
|
||||
<u--input v-model="form.brand" placeholder="请填写品牌"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="药品包装" prop="packaging" required >
|
||||
<u--input v-model="form.packaging" placeholder="请填写药品包装"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="包装单位" prop="packageUnitName" required @click="handlePackageUnit">
|
||||
<u--input v-model="form.packageUnitName" disabled disabledColor="#ffffff" placeholder="请选择包装单位"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="生产厂家" prop="manufacturers" required >
|
||||
<u--input v-model="form.manufacturers" placeholder="请填写生产厂家"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="是否进口" prop="isImportName" @click="handleIsImport">
|
||||
<u--input v-model="form.isImportName" disabled disabledColor="#ffffff" placeholder="请选择是否进口"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="规格" prop="specifications" >
|
||||
<u--input v-model="form.specifications" placeholder="请填写规格"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="规格单位" prop="unitName" @click="handleUnit">
|
||||
<u--input v-model="form.unitName" disabled disabledColor="#ffffff" placeholder="请选择规格单位"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="单个含量" prop="content" >
|
||||
<u--input v-model="form.content" placeholder="请填写单个含量"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="含量单位" prop="contentUnitName" @click="handleContentUnit">
|
||||
<u--input v-model="form.contentUnitName" disabled disabledColor="#ffffff" placeholder="请选择含量单位"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
<u-icon slot="right" name="arrow-down"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="生产地址" prop="address" >
|
||||
<u--input v-model="form.address" placeholder="请填写生产地址"
|
||||
inputAlign="right" border="none"></u--input>
|
||||
</u-form-item>
|
||||
<u-form-item label="功能主治" prop="indications" labelPosition="top">
|
||||
<u--textarea v-model="form.indications" placeholder="请填写功能主治" border="none" autoHeight inputAlign="right" count
|
||||
maxlength="2000" style="padding:18rpx 0;"></u--textarea>
|
||||
</u-form-item>
|
||||
<u-form-item label="贮藏" prop="storage" labelPosition="top">
|
||||
<u--textarea v-model="form.storage" placeholder="请填写贮藏" border="none" autoHeight inputAlign="right" count
|
||||
maxlength="2000" style="padding:18rpx 0;"></u--textarea>
|
||||
</u-form-item>
|
||||
<u-form-item label="药品成分" prop="ingredients" labelPosition="top">
|
||||
<u--textarea v-model="form.ingredients" placeholder="请填写药品成分" border="none" autoHeight inputAlign="right" count
|
||||
maxlength="2000" style="padding:18rpx 0;"></u--textarea>
|
||||
</u-form-item>
|
||||
<u-form-item label="用法用量" prop="usage" labelPosition="top">
|
||||
<u--textarea v-model="form.usage" placeholder="请填写用法用量" border="none" autoHeight inputAlign="right" count
|
||||
maxlength="2000" style="padding:18rpx 0;"></u--textarea>
|
||||
</u-form-item>
|
||||
<u-form-item label="性状" prop="character" labelPosition="top">
|
||||
<u--textarea v-model="form.character" placeholder="请填写性状" border="none" autoHeight inputAlign="right" count
|
||||
maxlength="2000" style="padding:18rpx 0;"></u--textarea>
|
||||
</u-form-item>
|
||||
<u-form-item label="不良反应" prop="adverseReaction" labelPosition="top">
|
||||
<u--textarea v-model="form.adverseReaction" placeholder="请填写不良反应" border="none" autoHeight inputAlign="right" count
|
||||
maxlength="2000" style="padding:18rpx 0;"></u--textarea>
|
||||
</u-form-item>
|
||||
<u-form-item label="备注" prop="remark" labelPosition="top">
|
||||
<u--textarea v-model="form.remark" placeholder="请填写备注" border="none" autoHeight inputAlign="right" count
|
||||
maxlength="2000" style="padding:18rpx 0;"></u--textarea>
|
||||
</u-form-item>
|
||||
</u--form>
|
||||
<view class="form-btn">
|
||||
<u-button type="primary" text="提交" @click="submit"></u-button>
|
||||
</view>
|
||||
</view>
|
||||
</view>
|
||||
<u-toast ref="uToast"></u-toast>
|
||||
<u-picker itemHeight="88" :show="showPerson" :columns="personList" keyName="name" @cancel="handlePersonCancel"
|
||||
@confirm="handlePersonConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showDosageForm" :columns="dosageFormList" keyName="dictLabel" @cancel="handleDosageFormCancel"
|
||||
@confirm="handleDosageFormConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showTreatmentType" :columns="treatmentTypeList" keyName="dictLabel" @cancel="handleTreatmentTypeCancel"
|
||||
@confirm="handleTreatmentTypeConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showClassification" :columns="classificationList" keyName="dictLabel" @cancel="handleClassificationCancel"
|
||||
@confirm="handleClassificationConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showCategory" :columns="categoryList" keyName="dictLabel" @cancel="handleCategoryCancel"
|
||||
@confirm="handleCategoryConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showPackageUnit" :columns="packageUnitList" keyName="dictLabel" @cancel="handlePackageUnitCancel"
|
||||
@confirm="handlePackageUnitConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showIsImport" :columns="isImportList" keyName="dictLabel" @cancel="handleIsImportCancel"
|
||||
@confirm="handleIsImportConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showUnit" :columns="unitList" keyName="dictLabel" @cancel="handleUnitCancel"
|
||||
@confirm="handleUnitConfirm"></u-picker>
|
||||
<u-picker itemHeight="88" :show="showContentUnit" :columns="contentUnitList" keyName="dictLabel" @cancel="handleContentUnitCancel"
|
||||
@confirm="handleContentUnitConfirm"></u-picker>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import {getMedicineBasic, addMedicineBasic, updateMedicineBasic } from '@/api/health/medicineBasic'
|
||||
const { proxy } = getCurrentInstance()
|
||||
import { getDicts } from '@/api/system/dict/data.js'
|
||||
import dayjs from 'dayjs'
|
||||
import {onLoad,onReady} from "@dcloudio/uni-app";
|
||||
// 计算属性与监听属性是在vue中而非uniap中 需要注意!!!
|
||||
import {reactive ,toRefs,ref,computed ,getCurrentInstance }from "vue";
|
||||
const datePickShow = ref(false)
|
||||
const title = ref("药品基础信息")
|
||||
const flag = ref('add')
|
||||
|
||||
const dosageFormList = ref([])
|
||||
const showDosageForm = ref(false)
|
||||
|
||||
const treatmentTypeList = ref([])
|
||||
const showTreatmentType = ref(false)
|
||||
|
||||
const classificationList = ref([])
|
||||
const showClassification = ref(false)
|
||||
|
||||
const categoryList = ref([])
|
||||
const showCategory = ref(false)
|
||||
|
||||
const packageUnitList = ref([])
|
||||
const showPackageUnit = ref(false)
|
||||
|
||||
const isImportList = ref([])
|
||||
const showIsImport = ref(false)
|
||||
|
||||
const unitList = ref([])
|
||||
const showUnit = ref(false)
|
||||
|
||||
const contentUnitList = ref([])
|
||||
const showContentUnit = ref(false)
|
||||
|
||||
|
||||
const data = reactive({
|
||||
form: {
|
||||
id: null,
|
||||
name: null,
|
||||
classification: null,
|
||||
category: null,
|
||||
brand: null,
|
||||
packaging: null,
|
||||
manufacturers: null,
|
||||
treatmentType: null,
|
||||
isImport: null,
|
||||
ingredients: null,
|
||||
usage: null,
|
||||
dosageForm: null,
|
||||
createBy: null,
|
||||
createTime: null,
|
||||
updateBy: null,
|
||||
updateTime: null,
|
||||
delFlag: null,
|
||||
remark: null,
|
||||
code: null,
|
||||
specifications: null,
|
||||
unit: null,
|
||||
address: null,
|
||||
adverseReaction: null,
|
||||
content: null,
|
||||
contentUnit: null,
|
||||
character: null,
|
||||
storage: null,
|
||||
indications: null
|
||||
},
|
||||
rules: {
|
||||
name: [{ required: true, message: '药品全称不能为空', trigger:['change', 'blur'] }],
|
||||
shortName: [{ required: true, message: '药品简称不能为空', trigger: ['change', 'blur'] }],
|
||||
classificationName: [{ required: true, message: '药品分类不能为空', trigger: ['change', 'blur'] }],
|
||||
categoryName: [{ required: true, message: '类别不能为空', trigger: ['change', 'blur'] }],
|
||||
brand: [{ required: true, message: '品牌不能为空', trigger: ['change', 'blur'] }],
|
||||
packaging: [{ required: true, message: '药品包装不能为空', trigger: ['change', 'blur'] }],
|
||||
manufacturers: [{ required: true, message: '生产厂家不能为空', trigger: ['change', 'blur'] }],
|
||||
code: [{ required: true, message: '药品编码不能为空', trigger: ['change', 'blur'] }],
|
||||
dosageFormName: [{ required: true, message: '药品剂型不能为空', trigger: ['change', 'blur'] }]
|
||||
}
|
||||
})
|
||||
const { form, rules} = toRefs(data)
|
||||
|
||||
|
||||
onLoad((option) => {
|
||||
form.value.id = option.id
|
||||
flag.value = option.flag
|
||||
if(flag.value==null){
|
||||
if(form.value.id!=null){
|
||||
title.value="药品基础信息-修改"
|
||||
}else{
|
||||
title.value="药品基础信息-新增"
|
||||
}
|
||||
}else{
|
||||
title.value="药品基础信息-复制"
|
||||
}
|
||||
getData()
|
||||
})
|
||||
onReady(() => {
|
||||
form.value.dosingTime = dayjs(new Date().getTime()).format("YYYY-MM-DD HH:mm:ss")
|
||||
})
|
||||
function dictStr(val, arr) {
|
||||
let str = ''
|
||||
arr.map(item => {
|
||||
if (item.dictValue === val) {
|
||||
str = item.dictLabel
|
||||
}
|
||||
})
|
||||
return str
|
||||
}
|
||||
function getData() {
|
||||
// 类型
|
||||
getDicts('dosage_form').then(res => {
|
||||
dosageFormList.value =[res.data]
|
||||
})
|
||||
// 类型
|
||||
getDicts('mar_type').then(res => {
|
||||
treatmentTypeList.value =[res.data]
|
||||
})
|
||||
// 类型
|
||||
getDicts('medicine_classification').then(res => {
|
||||
classificationList.value =[res.data]
|
||||
})
|
||||
// 类型
|
||||
getDicts('medicine_category').then(res => {
|
||||
categoryList.value =[res.data]
|
||||
})
|
||||
// 类型
|
||||
getDicts('package_unit').then(res => {
|
||||
packageUnitList.value =[res.data]
|
||||
})
|
||||
// 类型
|
||||
getDicts('is_import').then(res => {
|
||||
isImportList.value =[res.data]
|
||||
})
|
||||
// 类型
|
||||
getDicts('medical_unit').then(res => {
|
||||
unitList.value =[res.data]
|
||||
})
|
||||
// 类型
|
||||
getDicts('content_unit').then(res => {
|
||||
contentUnitList.value =[res.data]
|
||||
})
|
||||
|
||||
if(form.value.id!=null){
|
||||
getMedicineBasic(form.value.id).then(res => {
|
||||
form.value = res.data
|
||||
getDicts('dosage_form').then(result => {
|
||||
form.value.dosageFormName=dictStr(form.value.dosageForm, result.data)
|
||||
})
|
||||
getDicts('mar_type').then(result => {
|
||||
form.value.treatmentTypeName=dictStr(form.value.treatmentType, result.data)
|
||||
})
|
||||
getDicts('medicine_classification').then(result => {
|
||||
form.value.classificationName=dictStr(form.value.classification, result.data)
|
||||
})
|
||||
getDicts('medicine_category').then(result => {
|
||||
form.value.categoryName=dictStr(form.value.category, result.data)
|
||||
})
|
||||
getDicts('package_unit').then(result => {
|
||||
form.value.packageUnitName=dictStr(form.value.packageUnit, result.data)
|
||||
})
|
||||
getDicts('is_import').then(result => {
|
||||
form.value.isImportName=dictStr(form.value.isImport, result.data)
|
||||
})
|
||||
getDicts('medical_unit').then(result => {
|
||||
form.value.unitName=dictStr(form.value.unit, result.data)
|
||||
})
|
||||
getDicts('content_unit').then(result => {
|
||||
form.value.contentUnitName=dictStr(form.value.contentUnit, result.data)
|
||||
})
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
function handleDosageForm() {
|
||||
if (dosageFormList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品剂型为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showDosageForm.value = true
|
||||
}
|
||||
}
|
||||
function handleDosageFormConfirm(e) {
|
||||
form.value.dosageFormName = e.value[0].dictLabel
|
||||
form.value.dosageForm = e.value[0].dictValue
|
||||
showDosageForm.value = false
|
||||
}
|
||||
function handleDosageFormCancel() {
|
||||
showDosageForm.value = false
|
||||
}
|
||||
|
||||
function handleTreatmentType() {
|
||||
if (treatmentTypeList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品来源为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showTreatmentType.value = true
|
||||
}
|
||||
}
|
||||
function handleTreatmentTypeConfirm(e) {
|
||||
form.value.treatmentTypeName = e.value[0].dictLabel
|
||||
form.value.treatmentType = e.value[0].dictValue
|
||||
showTreatmentType.value = false
|
||||
}
|
||||
function handleTreatmentTypeCancel() {
|
||||
showTreatmentType.value = false
|
||||
}
|
||||
|
||||
function handleClassification() {
|
||||
if (classificationList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品来源为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showClassification.value = true
|
||||
}
|
||||
}
|
||||
function handleClassificationConfirm(e) {
|
||||
form.value.classificationName = e.value[0].dictLabel
|
||||
form.value.classification = e.value[0].dictValue
|
||||
showClassification.value = false
|
||||
}
|
||||
function handleClassificationCancel() {
|
||||
showClassification.value = false
|
||||
}
|
||||
|
||||
function handleCategory() {
|
||||
if (categoryList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品来源为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showCategory.value = true
|
||||
}
|
||||
}
|
||||
function handleCategoryConfirm(e) {
|
||||
form.value.categoryName = e.value[0].dictLabel
|
||||
form.value.category = e.value[0].dictValue
|
||||
showCategory.value = false
|
||||
}
|
||||
function handleCategoryCancel() {
|
||||
showCategory.value = false
|
||||
}
|
||||
|
||||
function handlePackageUnit() {
|
||||
if (packageUnitList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品来源为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showPackageUnit.value = true
|
||||
}
|
||||
}
|
||||
function handlePackageUnitConfirm(e) {
|
||||
form.value.packageUnitName = e.value[0].dictLabel
|
||||
form.value.packageUnit = e.value[0].dictValue
|
||||
showPackageUnit.value = false
|
||||
}
|
||||
function handlePackageUnitCancel() {
|
||||
showPackageUnit.value = false
|
||||
}
|
||||
|
||||
function handleIsImport() {
|
||||
if (isImportList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品来源为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showIsImport.value = true
|
||||
}
|
||||
}
|
||||
function handleIsImportConfirm(e) {
|
||||
form.value.isImportName = e.value[0].dictLabel
|
||||
form.value.isImport = e.value[0].dictValue
|
||||
showIsImport.value = false
|
||||
}
|
||||
function handleIsImportCancel() {
|
||||
showIsImport.value = false
|
||||
}
|
||||
|
||||
function handleUnit() {
|
||||
if (unitList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品来源为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showUnit.value = true
|
||||
}
|
||||
}
|
||||
function handleUnitConfirm(e) {
|
||||
form.value.unitName = e.value[0].dictLabel
|
||||
form.value.unit = e.value[0].dictValue
|
||||
showUnit.value = false
|
||||
}
|
||||
function handleUnitCancel() {
|
||||
showUnit.value = false
|
||||
}
|
||||
|
||||
function handleContentUnit() {
|
||||
if (contentUnitList.value[0].length === 0) {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '药品来源为空 ', type: 'warning'
|
||||
})
|
||||
} else {
|
||||
showContentUnit.value = true
|
||||
}
|
||||
}
|
||||
function handleContentUnitConfirm(e) {
|
||||
form.value.contentUnitName = e.value[0].dictLabel
|
||||
form.value.contentUnit = e.value[0].dictValue
|
||||
showContentUnit.value = false
|
||||
}
|
||||
function handleContentUnitCancel() {
|
||||
showContentUnit.value = false
|
||||
}
|
||||
function submit() {
|
||||
proxy.$refs['uForm'].validate().then(() => {
|
||||
if (form.value.id != null) {
|
||||
if(flag.value==null){
|
||||
updateMedicineBasic(form.value).then(res => {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '修改成功', complete() {
|
||||
uni.navigateTo({ url: `/pages/health/medicineBasic/list` })
|
||||
}
|
||||
})
|
||||
})
|
||||
}else {
|
||||
form.value.id == null
|
||||
addMedicineBasic(form.value).then(res => {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '新增成功', complete() {
|
||||
uni.navigateTo({ url: `/pages/health/medicineBasic/list` })
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
}else {
|
||||
addMedicineBasic(form.value).then(res => {
|
||||
proxy.$refs['uToast'].show({
|
||||
message: '新增成功', complete() {
|
||||
uni.navigateTo({ url: `/pages/health/medicineBasic/list` })
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
})
|
||||
}
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.section {
|
||||
margin: 24rpx;
|
||||
padding: 16rpx 24rpx;
|
||||
background-color: #fff;
|
||||
border-radius: 8rpx;
|
||||
|
||||
.section-title {
|
||||
width: 360rpx;
|
||||
color: #333333;
|
||||
line-height: 44rpx;
|
||||
font-size: 30rpx;
|
||||
border-left: 6rpx solid #2681FF;
|
||||
padding-left: 26rpx;
|
||||
}
|
||||
|
||||
.form-view {
|
||||
padding: 20rpx 0rpx 0 10rpx;
|
||||
|
||||
.form-btn {
|
||||
padding-top: 20rpx;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user