Compare commits
56 Commits
99b507657f
...
devops
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8b72cc93a0 | ||
|
|
6819b17126 | ||
|
|
d9a35f0081 | ||
|
|
4b26e6f5d0 | ||
|
|
ebb28ed676 | ||
|
|
a059d2bd57 | ||
|
|
fde372007f | ||
|
|
9aed740388 | ||
|
|
8a20db021a | ||
|
|
8daf15cf3f | ||
|
|
ba8dc41c83 | ||
|
|
6744b18240 | ||
|
|
a3ea6d9c51 | ||
|
|
5fa30a0e0e | ||
|
|
6b030791bb | ||
|
|
d0922c5309 | ||
|
|
d46bb82086 | ||
|
|
1ead1b2e9a | ||
|
|
c5f4f9b356 | ||
|
|
3fbde7f193 | ||
|
|
e5abd1514b | ||
|
|
33ed4fe5d5 | ||
|
|
4051b31101 | ||
|
|
94b1788e8c | ||
|
|
7944a1a8e3 | ||
|
|
17b28025d8 | ||
|
|
0a6b77943f | ||
|
|
a599566b20 | ||
|
|
1a7031342f | ||
|
|
516a8edb5e | ||
|
|
f4e2100882 | ||
|
|
9f6998e042 | ||
|
|
f730850d93 | ||
|
|
0ef83a945f | ||
|
|
cbfd68f50c | ||
|
|
7762eb6d24 | ||
|
|
db1a323921 | ||
|
|
1a61475f57 | ||
|
|
356e6438e0 | ||
|
|
5fe82a68ef | ||
|
|
9b6e02810a | ||
|
|
f0a32ad868 | ||
|
|
ce64bfd54d | ||
|
|
a53d25fae2 | ||
|
|
08d5e0e4fd | ||
|
|
b23f8325f4 | ||
|
|
0adb2b1486 | ||
|
|
38082397a9 | ||
|
|
4d527dc8ec | ||
|
|
d90aca62e4 | ||
|
|
44f11be05c | ||
|
|
7a21ab3804 | ||
|
|
6bb4802f15 | ||
|
|
cfc8f3c8e0 | ||
|
|
3f26b8b6df | ||
|
|
350ca644cf |
@@ -100,7 +100,7 @@ export default {
|
||||
</template>
|
||||
</el-table-column>
|
||||
</ai-table>
|
||||
<ai-dialog v-model="dialog" title="认证材料" width="50vw" @close="userId='',getTableData()"
|
||||
<ai-dialog v-model="dialog" title="场地配置" width="50vw" @close="userId='',getTableData()"
|
||||
@open="getTreeData" customFooter>
|
||||
<el-button class="mar-b8" type="primary" @click="createNode(treeData)">新增根节点</el-button>
|
||||
<el-tree :data="treeData" :props="{label:'name'}" default-expand-all>
|
||||
|
||||
@@ -41,7 +41,7 @@
|
||||
<el-form-item required label="行政区划" prop="areaId">
|
||||
<ai-area-get v-model.trim="dialogForm.areaId" placeholder="请选择" :instance="instance"/>
|
||||
</el-form-item>
|
||||
<el-form-item required label="账户" prop="userName">
|
||||
<el-form-item required label="账号" prop="userName">
|
||||
<el-input v-model.trim="dialogForm.userName" placeholder="请输入..." clearable :maxLength="15"/>
|
||||
</el-form-item>
|
||||
<!-- <el-form-item required label="账号密码" prop="password" v-if="!isEdit" :rules="[{ required: true, message: '请输入密码' }]">-->
|
||||
@@ -58,6 +58,9 @@
|
||||
<el-form-item label="手机号码" prop="phone">
|
||||
<el-input v-model.trim="dialogForm.phone" placeholder="请输入..." clearable :maxLength="11"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="身份证号" prop="idCard" :rules="[{required:true,message:'请输入身份证号'}]">
|
||||
<ai-input v-model.trim="dialogForm.idCard" :maxLength="18"/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</ai-dialog>
|
||||
</section>
|
||||
@@ -87,7 +90,7 @@ export default {
|
||||
return !!this.dialogForm.id
|
||||
},
|
||||
dialogTitle() {
|
||||
return this.isEdit ? '功能分配' : '添加账号'
|
||||
return this.isEdit ? '编辑账号' : '添加账号'
|
||||
},
|
||||
colConfigs() {
|
||||
return [
|
||||
|
||||
@@ -13,7 +13,7 @@ const columns = {
|
||||
{label: "序号", type: "index"},
|
||||
{label: "疫苗名称", prop: "vaccineName"},
|
||||
{label: "用药方式", prop: "method"},
|
||||
{label: "药量", prop: "dosage"},
|
||||
{label: "药量(ml)", prop: "dosage"},
|
||||
{label: "生产厂家", prop: "factory"},
|
||||
{label: "厂家批号", prop: "batchNumber"},
|
||||
{label: "免疫时间", prop: "immunityTime"},
|
||||
@@ -23,7 +23,7 @@ const columns = {
|
||||
treatmentList: [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "药品名称", prop: "drugName"},
|
||||
{label: "药量", prop: "dosage"},
|
||||
{label: "药量(ml)", prop: "dosage"},
|
||||
{label: "生产厂家", prop: "factory"},
|
||||
{label: "厂家批号", prop: "batchNumber"},
|
||||
{label: "疾病名称", prop: "diseaseName"},
|
||||
|
||||
@@ -76,8 +76,8 @@ export default {
|
||||
<ai-select placeholder="全部类别" v-model="search.category" dict="category"/>
|
||||
<ai-select placeholder="全部品种" v-model="search.variety" dict="variety"/>
|
||||
<ai-search label="入栏日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
</template>
|
||||
</ai-search-bar>
|
||||
|
||||
@@ -12,19 +12,19 @@ export default {
|
||||
},
|
||||
computed: {
|
||||
currentPage() {
|
||||
let {hash} = this.$route
|
||||
let { hash } = this.$route
|
||||
return ["#claim", "#add"].includes(hash) ? add : list
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety")
|
||||
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety", "productType")
|
||||
},
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<section class="AppClaimApply">
|
||||
<component :is="currentPage" v-bind="$props"/>
|
||||
<component :is="currentPage" v-bind="$props" />
|
||||
</section>
|
||||
</template>
|
||||
|
||||
|
||||
@@ -1,17 +1,17 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import { mapState } from "vuex"
|
||||
import AiEartagPicker from "@project/xumu/components/AiEartagPicker.vue";
|
||||
|
||||
const records = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "报案号", prop: "reportNo"},
|
||||
{label: "审批状态", prop: "auditStatus", dict: "auditStatus"},
|
||||
{label: "审批时间", prop: "auditTime"},
|
||||
{label: "审批人", prop: "auditName"},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "报案号", prop: "reportNo" },
|
||||
{ label: "审批状态", prop: "auditStatus", dict: "auditStatus" },
|
||||
{ label: "审批时间", prop: "auditTime" },
|
||||
{ label: "审批人", prop: "auditName" },
|
||||
]
|
||||
export default {
|
||||
name: "claimAdd",
|
||||
components: {AiEartagPicker},
|
||||
components: { AiEartagPicker },
|
||||
props: {
|
||||
instance: Function,
|
||||
permissions: Function,
|
||||
@@ -19,7 +19,7 @@ export default {
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: []},
|
||||
detail: { detailList: [], list: [] },
|
||||
records
|
||||
}
|
||||
},
|
||||
@@ -32,17 +32,17 @@ export default {
|
||||
},
|
||||
isClaim: v => v.$route.hash == "#claim",
|
||||
formImages: v => [
|
||||
{label: "勘察报告书", prop: "surveyPicture", rules: {required: v.isClaim, message: '请上传 勘察报告书'}},
|
||||
{label: "无害化回执单", prop: "receiptPicture", rules: {required: v.isClaim, message: '请上传 无害化回执单'}},
|
||||
{ label: "勘察报告书", prop: "surveyPicture", rules: { required: v.isClaim, message: '请上传 勘察报告书' } },
|
||||
{ label: "无害化回执单", prop: "receiptPicture", rules: { required: v.isClaim, message: '请上传 无害化回执单' } },
|
||||
],
|
||||
columns: v => [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber"},
|
||||
{label: "身长测量照片", prop: "heightPicture", upload: {instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1}},
|
||||
{label: "电子耳标照片", prop: "earNumberPicture", upload: {instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1}},
|
||||
{label: "防疫耳标照片", prop: "preventionPicture", upload: {instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1}},
|
||||
{label: "无害化处理照片", prop: "harmlessPicture", upload: {instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1}},
|
||||
{label: "报案号", prop: "reportNo", hide: v.isClaim},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "生物芯片耳标号", prop: "biochipEarNumber" },
|
||||
{ label: "身长测量照片", prop: "heightPicture", upload: { instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "电子耳标照片", prop: "earNumberPicture", upload: { instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "防疫耳标照片", prop: "preventionPicture", upload: { instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "无害化处理照片", prop: "harmlessPicture", upload: { instance: v.instance, readonly: !v.isClaim, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "报案号", prop: "reportNo", hide: v.isClaim },
|
||||
].filter(e => !e.hide),
|
||||
selectedEartags: v => v.detail.list?.length || 0,
|
||||
},
|
||||
@@ -51,17 +51,18 @@ export default {
|
||||
this.$router.push(params)
|
||||
},
|
||||
getDetail() {
|
||||
const {id} = this.$route.query
|
||||
return id && this.instance.post("/api/insurance/claim/apply/getInfo", null, {params: {orderNo: id}}).then(res => {
|
||||
const { id } = this.$route.query
|
||||
return id && this.instance.post("/api/insurance/claim/apply/getInfo", null, { params: { orderNo: id } }).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
return this.detail = {...detail}
|
||||
detail.detailList = detail.detailList || []
|
||||
return this.detail = { ...detail }
|
||||
}
|
||||
})
|
||||
},
|
||||
submit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
this.instance.post("/api/insurance/claim/apply/add", {...this.detail}).then(res => {
|
||||
this.instance.post("/api/insurance/claim/apply/add", { ...this.detail }).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -82,43 +83,44 @@ export default {
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid">
|
||||
<el-form-item label="养殖场" prop="farmId">
|
||||
<b v-text="detail.farmName"/>
|
||||
<b v-text="detail.farmName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="承保公司" prop="companyId">
|
||||
<b v-text="detail.companyName"/>
|
||||
<b v-text="detail.companyName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="投保类型">
|
||||
<ai-input :value="dict.getLabel('insureType',detail.insureType)" :edit="!1"/>
|
||||
<ai-input :value="dict.getLabel('insureType', detail.insureType)" :edit="!1" />
|
||||
</el-form-item>
|
||||
<el-form-item label="保险产品" prop="productType">
|
||||
<b v-text="detail.productType"/>
|
||||
<b v-text="dict.getLabel('productType',detail.productType)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系人">
|
||||
<ai-input v-model="detail.contacts" :edit="!1"/>
|
||||
<ai-input v-model="detail.contacts" :edit="!1" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系电话">
|
||||
<ai-input v-model="detail.phone" :edit="!1"/>
|
||||
<ai-input v-model="detail.phone" :edit="!1" />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="投保对象">
|
||||
<template #right v-if="isClaim">
|
||||
<ai-eartag-picker @select="v=>detail.detailList=v" :instance="instance"
|
||||
:action="`/api/insurance/claim/apply/getClaimEarNumberList?orderNo=${detail.orderNo}`">
|
||||
<ai-eartag-picker @select="v => detail.detailList = v.map(e=>({biochipEarNumber:e}))" :instance="instance"
|
||||
:action="`/api/insurance/claim/apply/getClaimEarNumberList?orderNo=${detail.orderNo}`">
|
||||
<el-button type="text">选择</el-button>
|
||||
</ai-eartag-picker>
|
||||
</template>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`投保标的共${detail.insureNumber||0}只,已理赔标的共 @v 只`" color="red" :value="selectedEartags"/>
|
||||
<ai-table :tableData="detail.detailList" :colConfigs="columns" :isShowPagination="!1" hideOptions/>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`投保标的共${detail.insureNumber || 0}只,已理赔标的共 @v 只`" color="red"
|
||||
:value="selectedEartags" />
|
||||
<ai-table :tableData="detail.detailList" :colConfigs="columns" :isShowPagination="!1" hideOptions />
|
||||
</ai-card>
|
||||
<ai-card title="理赔材料" v-if="isClaim">
|
||||
<div class="font-12 mar-b8">只能上传JPG/PNG文件,且不超过2M,一次最多5张</div>
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" :instance="instance" value-is-url :limit="5"/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" :instance="instance" value-is-url :limit="5" />
|
||||
</el-form-item>
|
||||
</ai-card>
|
||||
<ai-card title="理赔记录" v-else>
|
||||
<ai-table :tableData="detail.list" :colConfigs="records" :isShowPagination="!1" hideOptions/>
|
||||
<ai-table :tableData="detail.list" :colConfigs="records" :isShowPagination="!1" hideOptions />
|
||||
</ai-card>
|
||||
</el-form>
|
||||
<div slot="footer">
|
||||
|
||||
@@ -48,7 +48,7 @@ export default {
|
||||
getTableData() {
|
||||
this.instance.post("/api/insurance/claim/apply/page", {...this.page, ...this.search}).then(res => {
|
||||
if (res?.data) {
|
||||
this.tableData = res.data?.records.map(e => ({...e, permit: `${e.status}` + e.auditStatus}))
|
||||
this.tableData = res.data?.records.map(e => ({...e, permit: e.remarks == "可申请理赔"}))
|
||||
this.page.total = res.data.total
|
||||
}
|
||||
})
|
||||
@@ -67,8 +67,8 @@ export default {
|
||||
<ai-input placeholder="投保订单号" v-model="search.orderNo"/>
|
||||
<ai-select placeholder="全部投保类型" v-model="search.insureType" dict="insureType"/>
|
||||
<ai-search label="投保日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="养殖户" v-model="search.applyName"/>
|
||||
<ai-input placeholder="养殖场" v-model="search.farmName"/>
|
||||
@@ -84,7 +84,7 @@ export default {
|
||||
<el-table-column slot="options" label="操作" fixed="right" align="center">
|
||||
<template slot-scope="{row}">
|
||||
<div class="table-options">
|
||||
<template v-if="['12'].includes(row.permit)">
|
||||
<template v-if="row.permit">
|
||||
<el-button type="text" @click="dialog=true,$set(form,'id',row.orderNo)">理赔</el-button>
|
||||
</template>
|
||||
<el-button v-else type="text" @click="$router.push({hash:'#add',query:{id:row.orderNo}})">查看</el-button>
|
||||
|
||||
@@ -12,19 +12,19 @@ export default {
|
||||
},
|
||||
computed: {
|
||||
currentPage() {
|
||||
let {hash} = this.$route
|
||||
let { hash } = this.$route
|
||||
return ["#audit", "#add"].includes(hash) ? add : list
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety")
|
||||
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety", "productType")
|
||||
},
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<section class="AppClaimAudit">
|
||||
<component :is="currentPage" v-bind="$props"/>
|
||||
<component :is="currentPage" v-bind="$props" />
|
||||
</section>
|
||||
</template>
|
||||
|
||||
|
||||
@@ -90,7 +90,7 @@ export default {
|
||||
<ai-input :value="dict.getLabel('insureType',detail.insureType)" :edit="!1"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="保险产品" prop="productType">
|
||||
<b v-text="detail.productType"/>
|
||||
<b v-text="dict.getLabel('productType',detail.productType)"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="联系人">
|
||||
<ai-input v-model="detail.contacts" :edit="!1"/>
|
||||
|
||||
@@ -68,8 +68,8 @@ export default {
|
||||
<ai-select placeholder="全部审批状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-select placeholder="全部投保状态" v-model="search.status" dict="insureStatus"/>
|
||||
<ai-search label="投保日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="养殖户" v-model="search.applyName"/>
|
||||
<ai-input placeholder="养殖场" v-model="search.farmName"/>
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import { mapState } from "vuex"
|
||||
import AiAudit from "../components/AiAudit.vue";
|
||||
|
||||
export default {
|
||||
name: "deathAdd",
|
||||
@@ -10,9 +11,10 @@ export default {
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: []}
|
||||
detail: { detailList: [] }
|
||||
}
|
||||
},
|
||||
components:{AiAudit},
|
||||
computed: {
|
||||
...mapState(["user"]),
|
||||
userinfo: v => v.user.info || {},
|
||||
@@ -22,10 +24,10 @@ export default {
|
||||
},
|
||||
isAudit: v => v.$route.hash == "#audit",
|
||||
formImages: v => [
|
||||
{label: "身长测量照片", prop: "heightPic"},
|
||||
{label: "生物芯片照片", prop: "biochipPic"},
|
||||
{label: "防疫耳标照片", prop: "preventionPic"},
|
||||
{label: "其他说明照片", prop: "otherPic"},
|
||||
{ label: "身长测量照片", prop: "heightPic" },
|
||||
{ label: "生物芯片照片", prop: "biochipPic" },
|
||||
{ label: "防疫耳标照片", prop: "preventionPic" },
|
||||
{ label: "其他说明照片", prop: "otherPic" },
|
||||
],
|
||||
},
|
||||
methods: {
|
||||
@@ -33,22 +35,22 @@ export default {
|
||||
this.$router.push(params)
|
||||
},
|
||||
getDetail() {
|
||||
const {id} = this.$route.query
|
||||
return id && this.instance.post("/api/breed/death/page", null, {params: {id}}).then(res => {
|
||||
if (res?.data?.records) {
|
||||
const { id } = this.$route.query
|
||||
return id && this.instance.post("/api/breed/death/getAuditPage", { id }).then(res => {
|
||||
if (res?.data?.records?.[0]) {
|
||||
const detail = res.data.records[0] || {}
|
||||
if (detail.picture) {
|
||||
Object.entries(JSON.parse(detail.picture)).forEach(([key, value]) => {
|
||||
detail[key] = value
|
||||
})
|
||||
}
|
||||
return this.detail = {...detail}
|
||||
return this.detail = { ...detail }
|
||||
}
|
||||
})
|
||||
},
|
||||
submit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
this.instance.post("/api/breed/death/audit", {...this.detail}).then(res => {
|
||||
this.instance.post("/api/breed/death/audit", { ...this.detail }).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -69,55 +71,55 @@ export default {
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid c-4">
|
||||
<el-form-item label="生物芯片耳标号" class="row">
|
||||
<b v-text="detail.biochipEarNumber"/>
|
||||
<b v-text="detail.biochipEarNumber" />
|
||||
</el-form-item>
|
||||
<el-form-item label="养殖场" prop="farmId">
|
||||
<b v-text="detail.farmName"/>
|
||||
<b v-text="detail.farmName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="养殖舍" prop="houseId">
|
||||
<b v-text="detail.houseName"/>
|
||||
<b v-text="detail.houseName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="养殖栏" prop="penId">
|
||||
<b v-text="detail.penName"/>
|
||||
<b v-text="detail.penName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="电子耳标号" prop="electronicEarNumber">
|
||||
<b v-text="detail.electronicEarNumber"/>
|
||||
<b v-text="detail.electronicEarNumber" />
|
||||
</el-form-item>
|
||||
<el-form-item label="原厂耳标号" prop="category">
|
||||
<b v-text="detail.originalEarNumber"/>
|
||||
<b v-text="detail.originalEarNumber" />
|
||||
</el-form-item>
|
||||
<el-form-item label="类别" prop="category">
|
||||
<b v-text="detail.category"/>
|
||||
<b v-text="dict.getLabel('category', detail.category)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="品种" prop="variety">
|
||||
<b v-text="detail.variety"/>
|
||||
<b v-text="dict.getLabel('variety', detail.variety)" />
|
||||
</el-form-item>
|
||||
<div class="row flex">
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" value-is-url readonly/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" value-is-url readonly />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="死亡信息">
|
||||
<el-form-item label="死亡原因">
|
||||
<b v-text="dict.getLabel('deathReason',detail.reason)"/>
|
||||
<b v-text="dict.getLabel('deathReason', detail.reason)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="死亡日期">
|
||||
<b v-text="detail.deathTime"/>
|
||||
<b v-text="detail.deathTime" />
|
||||
</el-form-item>
|
||||
<el-form-item label="备注">
|
||||
<b v-text="detail.remark"/>
|
||||
<b v-text="detail.remark" />
|
||||
</el-form-item>
|
||||
</ai-card>
|
||||
<ai-card title="审核信息">
|
||||
<div class="grid">
|
||||
<template v-if="isAudit">
|
||||
<el-form-item label="审批状态" prop="auditStatus" :rules="{required:true,message:'请选择审批状态'}">
|
||||
<ai-select v-model="detail.auditStatus" dict="auditStatus"/>
|
||||
<el-form-item label="审批状态" prop="auditStatus" :rules="{ required: true, message: '请选择审批状态' }">
|
||||
<ai-audit @change="v => $set(detail, 'auditStatus', v)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="意见">
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remark"/>
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remark" />
|
||||
</el-form-item>
|
||||
</template>
|
||||
<template v-else>
|
||||
|
||||
@@ -68,12 +68,12 @@ export default {
|
||||
<ai-select placeholder="全部养殖栏" v-model="search.penId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.houseId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-select placeholder="全部审核状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="死亡日期">
|
||||
<el-date-picker v-model="search.deathBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.deathEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.deathBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.deathEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-search label="登记日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="原场耳标号" v-model="search.originalEarNumber"/>
|
||||
<ai-input placeholder="生物芯片耳标号" v-model="search.biochipEarNumber"/>
|
||||
@@ -82,7 +82,7 @@ export default {
|
||||
</ai-search-bar>
|
||||
<ai-search-bar>
|
||||
<template #left>
|
||||
<ai-download :instance="instance" url="/api/breed/death/export" :params="{...search,...page}" :fileName="`${pageTitle}导出表-${Date.now()}`"/>
|
||||
<ai-download :instance="instance" url="/api/breed/death/exportAudit" :params="{...search,...page}" :fileName="`${pageTitle}导出表-${Date.now()}`"/>
|
||||
</template>
|
||||
</ai-search-bar>
|
||||
<ai-table :tableData="tableData" :colConfigs="columns" :dict="dict" @getList="getTableData"
|
||||
|
||||
@@ -12,19 +12,19 @@ export default {
|
||||
},
|
||||
computed: {
|
||||
currentPage() {
|
||||
let {hash} = this.$route
|
||||
let { hash } = this.$route
|
||||
return hash == "#add" ? add : list
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {}
|
||||
created() {
|
||||
this.dict.load("yesOrNo", "category", "variety", "deathReason", "auditStatus")
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<section class="AppDeathManage">
|
||||
<component :is="currentPage" v-bind="$props"/>
|
||||
<component :is="currentPage" v-bind="$props" />
|
||||
</section>
|
||||
</template>
|
||||
|
||||
|
||||
@@ -1,14 +1,16 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import AiEartagRemote from "@project/xumu/components/AiEartagRemote.vue";
|
||||
|
||||
const formImages = [
|
||||
{label: "身长测量照片", prop: "heightPic", rules: {required: true, message: '请上传 身长测量照片'}},
|
||||
{label: "生物芯片照片", prop: "biochipPic", rules: {required: true, message: '请上传 生物芯片照片'}},
|
||||
{label: "防疫耳标照片", prop: "preventionPic", rules: {required: true, message: '请上传 防疫耳标照片'}},
|
||||
{label: "其他说明照片", prop: "otherPic", rules: {required: true, message: '请上传 其他说明照片'}},
|
||||
{label: "身长测量照片", prop: "heightPic",},
|
||||
{label: "生物芯片照片", prop: "biochipPic",},
|
||||
{label: "防疫耳标照片", prop: "preventionPic",},
|
||||
{label: "其他说明照片", prop: "otherPic",},
|
||||
]
|
||||
export default {
|
||||
name: "deathAdd",
|
||||
components: {AiEartagRemote},
|
||||
props: {
|
||||
instance: Function,
|
||||
permissions: Function,
|
||||
@@ -53,7 +55,7 @@ export default {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
const {biochipEarNumber, id, deathTime, heightPic, biochipPic, preventionPic, otherPic, reason, remarks} = this.detail
|
||||
this.instance.post("/api/breed/death/addOrEdit", {
|
||||
biochipEarNumber, id, deathTime, picture: {heightPic, biochipPic, preventionPic, otherPic}, reason, remarks
|
||||
biochipEarNumber, id, deathTime, picture: JSON.stringify({heightPic, biochipPic, preventionPic, otherPic}), reason, remarks
|
||||
}).then(res => {
|
||||
if (res?.code == 0 && res?.data != 1) {
|
||||
this.$confirm("是否返回列表页?", "提交成功").then(() => this.back()).catch(() => this.getDetail(biochipEarNumber))
|
||||
@@ -71,10 +73,12 @@ export default {
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
},
|
||||
handlerAutocomplete(value) {
|
||||
'biochipEarNumber|farmId|houseId|penId|electronicEarNumber|originalEarNumber|category|variety'.split("|").forEach(prop => this.$set(this.detail, prop, value[prop]))
|
||||
},
|
||||
},
|
||||
created() {
|
||||
this.dict.load("yesOrNo", "category", "variety", "deathReason")
|
||||
this.getDetail(this.$route.query.id)
|
||||
}
|
||||
}
|
||||
@@ -85,7 +89,7 @@ export default {
|
||||
<el-form size="small" label-width="120px" :model="detail" ref="detail">
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid c-4">
|
||||
<ai-input class="row" v-model="detail.biochipEarNumber" placeholder="请输入耳标号按回车查询,或扫描耳标号" @input="getDetail"/>
|
||||
<ai-eartag-remote :instance="instance" @enter="handlerAutocomplete" class="row"/>
|
||||
<el-form-item label="生物芯片耳标号">
|
||||
<b v-text="detail.biochipEarNumber"/>
|
||||
</el-form-item>
|
||||
@@ -101,7 +105,7 @@ export default {
|
||||
<el-form-item label="电子耳标号" prop="electronicEarNumber">
|
||||
<b v-text="detail.electronicEarNumber"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="原厂耳标号" prop="category">
|
||||
<el-form-item label="原厂耳标号" prop="originalEarNumber">
|
||||
<b v-text="detail.originalEarNumber"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="类别" prop="category">
|
||||
@@ -122,13 +126,13 @@ export default {
|
||||
</ai-card>
|
||||
<ai-card title="死亡录入">
|
||||
<div class="grid">
|
||||
<el-form-item label="死亡日期" prop="deathTime" :rules="[{required:true,message:'请选择死亡日期'}]">
|
||||
<el-date-picker v-if="isAdd||isEdit" v-model="detail.deathTime"/>
|
||||
<b v-text="detail.deathTime"/>
|
||||
<el-form-item label="死亡日期" prop="deathTime" :rules="[{required:isAdd||isEdit,message:'请选择死亡日期'}]">
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-if="isAdd||isEdit" v-model="detail.deathTime"/>
|
||||
<b v-else v-text="detail.deathTime"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="死亡原因" prop="reason" :rules="[{required:true,message:'请选择死亡原因'}]">
|
||||
<el-form-item label="死亡原因" prop="reason" :rules="[{required:isAdd||isEdit,message:'请选择死亡原因'}]">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.reason" dict="deathReason"/>
|
||||
<b v-text="detail.reason"/>
|
||||
<b v-else v-text="dict.getLabel('deathReason',detail.reason)"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="备注" prop="remark" class="row">
|
||||
<ai-input type="textarea" :row="3" v-model="detail.remark" :edit="isAdd||isEdit"/>
|
||||
|
||||
@@ -79,7 +79,6 @@ export default {
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.dict.load("auditStatus", "category", "variety")
|
||||
this.getTableData()
|
||||
}
|
||||
}
|
||||
@@ -94,12 +93,12 @@ export default {
|
||||
<ai-select placeholder="全部养殖栏" v-model="search.penId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.houseId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-select placeholder="全部审核状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="死亡日期">
|
||||
<el-date-picker v-model="search.deathBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.deathEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.deathBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.deathEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-search label="登记日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="原场耳标号" v-model="search.originalEarNumber"/>
|
||||
<ai-input placeholder="生物芯片耳标号" v-model="search.biochipEarNumber"/>
|
||||
|
||||
@@ -1,17 +1,6 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
|
||||
const columns = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber", edit: 1},
|
||||
{label: "电子耳标号", prop: "electronicEarNumber", edit: 1},
|
||||
{label: "原厂耳标号", prop: "originalEarNumber", edit: 1},
|
||||
{label: "戴耳标照片", prop: "picture", upload: {valueIsUrl: !0}},
|
||||
{label: "品种", prop: "variety", select: {dict: "variety"}},
|
||||
{label: "类别", prop: "category", select: {dict: "category"}},
|
||||
{label: "日龄/天", prop: "age", num: 1},
|
||||
{label: "体重/公斤", prop: "weight", num: 1},
|
||||
]
|
||||
export default {
|
||||
name: "etAdd",
|
||||
props: {
|
||||
@@ -22,7 +11,6 @@ export default {
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: []},
|
||||
columns,
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
@@ -34,6 +22,17 @@ export default {
|
||||
const appName = v.$parent.menuName || v.$parent.$options.label
|
||||
return v.$route.query.id ? v.isEdit ? `编辑${appName}` : `${appName}详情` : `新增${appName}`
|
||||
},
|
||||
columns: v => [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber", edit: 1},
|
||||
{label: "电子耳标号", prop: "electronicEarNumber", edit: 1},
|
||||
{label: "原厂耳标号", prop: "originalEarNumber", edit: 1},
|
||||
{label: "戴耳标照片", prop: "picture", upload: {valueIsUrl: !0, instance: v.instance, limit: 1}},
|
||||
{label: "品种", prop: "variety", select: {dict: "variety"}},
|
||||
{label: "类别", prop: "category", select: {dict: "category"}},
|
||||
{label: "日龄/天", prop: "age", num: 1},
|
||||
{label: "体重/公斤", prop: "weight", num: 1},
|
||||
]
|
||||
},
|
||||
methods: {
|
||||
back(params = {}) {
|
||||
|
||||
@@ -80,8 +80,8 @@ export default {
|
||||
<ai-select placeholder="全部类别" v-model="search.category" dict="category"/>
|
||||
<ai-select placeholder="全部品种" v-model="search.variety" dict="variety"/>
|
||||
<ai-search label="登记日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-search label="日龄">
|
||||
<el-input placeholder="最小日龄" v-model="search.beginAge" size="small" clearable/>
|
||||
|
||||
@@ -6,7 +6,7 @@ const columns = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "疫苗名称", prop: "vaccineName"},
|
||||
{label: "用药方式", prop: "method"},
|
||||
{label: "药量", prop: "dosage"},
|
||||
{label: "药量(ml)", prop: "dosage"},
|
||||
{label: "生产厂家", prop: "factory"},
|
||||
{label: "厂家批号", prop: "batchNumber"},
|
||||
{label: "免疫时间", prop: "immunityTime"},
|
||||
@@ -75,7 +75,8 @@ export default {
|
||||
},
|
||||
submit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
this.instance.post("/api/breed/immunity/update", this.form).then(res => {
|
||||
const action = !this.form.id ? "/api/breed/immunity/add" : "/api/breed/immunity/update"
|
||||
this.instance.post(action, this.form).then(res => {
|
||||
if (res?.code == 0) {
|
||||
this.dialog = false
|
||||
this.getDetail()
|
||||
@@ -86,7 +87,6 @@ export default {
|
||||
},
|
||||
created() {
|
||||
this.dict.load("yesOrNo", "category", "variety", "source")
|
||||
this.detail.treatmentTime = new Date()
|
||||
this.getDetail()
|
||||
}
|
||||
}
|
||||
@@ -129,7 +129,7 @@ export default {
|
||||
<template v-if="isAdd">
|
||||
<div class="grid c-3">
|
||||
<el-form-item label="免疫日期" prop="immunityTime" :rules="{required:true,message:'请选择 免疫日期'}">
|
||||
<el-date-picker v-model="detail.immunityTime"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="detail.immunityTime"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="疫苗名称" prop="vaccineName" :rules="{required:true,message:'请选择 疫苗名称'}">
|
||||
<ai-input v-model="detail.vaccineName"/>
|
||||
@@ -163,9 +163,9 @@ export default {
|
||||
</template>
|
||||
</ai-card>
|
||||
<ai-dialog v-model="dialog" title="免疫登记" @closed="form={}" @confirm="submit">
|
||||
<el-form size="small" label-width="120px" class="grid">
|
||||
<el-form size="small" label-width="120px" class="grid">
|
||||
<el-form-item label="免疫日期" prop="immunityTime" :rules="{required:true,message:'请选择 免疫日期'}">
|
||||
<el-date-picker v-model="form.immunityTime"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="form.immunityTime"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="疫苗名称" prop="vaccineName" :rules="{required:true,message:'请选择 疫苗名称'}">
|
||||
<ai-input v-model="form.vaccineName"/>
|
||||
|
||||
@@ -64,12 +64,12 @@ export default {
|
||||
<ai-select placeholder="全部养殖舍" v-model="search.houseId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.farmId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-select placeholder="全部养殖栏" v-model="search.penId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.houseId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-search label="免疫日期">
|
||||
<el-date-picker v-model="search.immunityBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.immunityEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.immunityBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.immunityEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-search label="登记日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<el-input placeholder="原场耳标号" v-model="search.originalEarNumber" dict="authStatus" size="small" clearable/>
|
||||
<el-input placeholder="生物芯片耳标号" v-model="search.biochipEarNumber" dict="authStatus" size="small" clearable/>
|
||||
|
||||
@@ -17,7 +17,7 @@ export default {
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety")
|
||||
this.dict.load("insuranceAuditStatus", "insureType", "insureStatus", "category", "variety")
|
||||
},
|
||||
}
|
||||
</script>
|
||||
|
||||
@@ -33,11 +33,11 @@ export default {
|
||||
isAdd: v => !v.$route.query.id,
|
||||
isEdit: v => v.$route.query.edit == 1,
|
||||
formImages: v => [
|
||||
{label: "身份证(正面)", prop: "frontCard", rules: {required: v.isAdd||v.isEdit, message: '请上传 身份证(正面)'}},
|
||||
{label: "身份证(反面)", prop: "reverseCard", rules: {required: v.isAdd||v.isEdit, message: '请上传 身份证(反面)'}},
|
||||
{label: "营业执照", prop: "businessPic", rules: {required: v.isAdd||v.isEdit, message: '请上传 营业执照'}},
|
||||
{label: "畜禽经营许可证", prop: "breedPic", rules: {required: v.isAdd||v.isEdit, message: '请上传 畜禽经营许可证'}},
|
||||
{label: "动物防疫条件许可证", prop: "prevention", rules: {required: v.isAdd||v.isEdit, message: '请上传 动物防疫条件许可证'}},
|
||||
{label: "身份证(正面)", prop: "frontCard", rules: {required: v.isAdd || v.isEdit, message: '请上传 身份证(正面)'}},
|
||||
{label: "身份证(反面)", prop: "reverseCard", rules: {required: v.isAdd || v.isEdit, message: '请上传 身份证(反面)'}},
|
||||
{label: "营业执照", prop: "businessPic", rules: {required: v.isAdd || v.isEdit, message: '请上传 营业执照'}},
|
||||
{label: "畜禽经营许可证", prop: "breedPic", rules: {required: v.isAdd || v.isEdit, message: '请上传 畜禽经营许可证'}},
|
||||
{label: "动物防疫条件许可证", prop: "prevention", rules: {required: v.isAdd || v.isEdit, message: '请上传 动物防疫条件许可证'}},
|
||||
]
|
||||
},
|
||||
methods: {
|
||||
@@ -49,7 +49,7 @@ export default {
|
||||
return id && this.instance.post("/api/insurance/apply/getInfo", null, {params: {id}}).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
detail.detailList = detail.weightList || []
|
||||
detail.detailList = detail.detailList || []
|
||||
let {farmPicture: picture = "{}"} = detail
|
||||
picture = JSON.parse(picture)
|
||||
return this.detail = {...detail, ...picture}
|
||||
@@ -69,6 +69,7 @@ export default {
|
||||
},
|
||||
submit(submitType) {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
const earNumberList = this.detail.detailList.map(e => e.biochipEarNumber)
|
||||
const farmPicture = {}
|
||||
this.formImages.forEach(e => {
|
||||
const {prop} = e
|
||||
@@ -78,7 +79,7 @@ export default {
|
||||
}
|
||||
})
|
||||
this.detail.farmPicture = JSON.stringify(farmPicture)
|
||||
this.instance.post("/api/insurance/apply/addOrEdit", {...this.detail, submitType}).then(res => {
|
||||
this.instance.post("/api/insurance/apply/addOrEdit", {...this.detail, submitType, earNumberList}).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -110,7 +111,7 @@ export default {
|
||||
<el-form-item label="保险产品" prop="productType" :rules="{required: isAdd||isEdit,message:'请选择 保险产品'}">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.productType" :select-list="getProducts(detail.companyId)" :prop="{label:'name',value:'productType'}"
|
||||
@select="v=>$set(detail,'insureType',v.children[0].insureType)"/>
|
||||
<b v-else v-text="detail.productType"/>
|
||||
<b v-else v-text="dict.getLabel('productType', detail.productType)"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="投保类型">
|
||||
<ai-input :value="dict.getLabel('insureType',detail.insureType)" placeholder="根据保险产品自动带出" :edit="isAdd||isEdit" readonly/>
|
||||
@@ -125,7 +126,7 @@ export default {
|
||||
</ai-card>
|
||||
<ai-card title="投保对象">
|
||||
<template #right v-if="isAdd||isEdit">
|
||||
<ai-eartag-picker @select="v=>detail.detailList=v" :instance="instance"
|
||||
<ai-eartag-picker @select="v=>detail.detailList=v" :instance="instance" value-key="biochipEarNumber"
|
||||
:action="`/api/insurance/apply/getEarNumberList?farmId=${detail.farmId}`">
|
||||
<el-button type="text">选择</el-button>
|
||||
</ai-eartag-picker>
|
||||
@@ -141,7 +142,7 @@ export default {
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="审核信息" v-if="!(isAdd||isEdit)">
|
||||
<el-form-item label="审核状态">{{ dict.getLabel('auditStatus', detail.auditStatus) }}</el-form-item>
|
||||
<el-form-item label="审核状态">{{ dict.getLabel('insuranceAuditStatus', detail.auditStatus) }}</el-form-item>
|
||||
<el-form-item label="审核时间">{{ detail.auditTime }}</el-form-item>
|
||||
<el-form-item label="审核人">{{ detail.auditName }}</el-form-item>
|
||||
<el-form-item label="保单订单号">{{ detail.orderNo }}</el-form-item>
|
||||
|
||||
@@ -9,7 +9,7 @@ const columns = [
|
||||
{label: "承保公司", prop: "companyName"},
|
||||
{label: "投保时间", prop: "createTime"},
|
||||
{label: "投保状态", prop: "status", width: 160, dict: "insureStatus"},
|
||||
{label: "审核状态", prop: "auditStatus", width: 120, dict: "auditStatus"},
|
||||
{label: "审核状态", prop: "auditStatus", width: 120, dict: "insuranceAuditStatus"},
|
||||
{label: "申请人", prop: "applyName", width: 120},
|
||||
]
|
||||
export default {
|
||||
@@ -80,8 +80,8 @@ export default {
|
||||
<ai-select placeholder="全部投保状态" v-model="search.status" dict="insureStatus"/>
|
||||
<ai-select placeholder="全部审批状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="投保日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
</template>
|
||||
</ai-search-bar>
|
||||
|
||||
@@ -12,19 +12,19 @@ export default {
|
||||
},
|
||||
computed: {
|
||||
currentPage() {
|
||||
let {hash} = this.$route
|
||||
let { hash } = this.$route
|
||||
return ["#add", "#audit"].includes(hash) ? add : list
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety")
|
||||
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety", "productType")
|
||||
},
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<section class="AppInsuranceAudit">
|
||||
<component :is="currentPage" v-bind="$props"/>
|
||||
<component :is="currentPage" v-bind="$props" />
|
||||
</section>
|
||||
</template>
|
||||
|
||||
|
||||
@@ -1,16 +1,18 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import { mapState } from "vuex"
|
||||
import AiEartagPicker from "@project/xumu/components/AiEartagPicker.vue";
|
||||
import AiIdcardRemote from "@project/xumu/components/AiIdcardRemote.vue";
|
||||
import AiAudit from "../components/AiAudit.vue";
|
||||
|
||||
const columns = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber"},
|
||||
{label: "类别", prop: "category", dict: "category"},
|
||||
{label: "品种", prop: "variety", dict: "variety"},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "生物芯片耳标号", prop: "biochipEarNumber" },
|
||||
{ label: "类别", prop: "category", dict: "category" },
|
||||
{ label: "品种", prop: "variety", dict: "variety" },
|
||||
]
|
||||
export default {
|
||||
name: "iaAdd",
|
||||
components: {AiEartagPicker},
|
||||
components: { AiIdcardRemote, AiEartagPicker, AiAudit },
|
||||
props: {
|
||||
instance: Function,
|
||||
permissions: Function,
|
||||
@@ -18,7 +20,7 @@ export default {
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: []},
|
||||
detail: { detailList: [] },
|
||||
columns,
|
||||
companyList: []
|
||||
}
|
||||
@@ -34,11 +36,11 @@ export default {
|
||||
isEdit: v => v.$route.query.edit == 1,
|
||||
isAudit: v => v.$route.hash == "#audit",
|
||||
formImages: v => [
|
||||
{label: "身份证(正面)", prop: "frontCard", rules: {required: v.isAdd, message: '请上传 身份证(正面)'}},
|
||||
{label: "身份证(反面)", prop: "reverseCard", rules: {required: v.isAdd, message: '请上传 身份证(反面)'}},
|
||||
{label: "营业执照", prop: "businessPic", rules: {required: v.isAdd, message: '请上传 营业执照'}},
|
||||
{label: "畜禽经营许可证", prop: "breedPic", rules: {required: v.isAdd, message: '请上传 畜禽经营许可证'}},
|
||||
{label: "动物防疫条件许可证", prop: "prevention", rules: {required: v.isAdd, message: '请上传 动物防疫条件许可证'}},
|
||||
{ label: "身份证(正面)", prop: "frontCard", rules: { required: v.isAdd, message: '请上传 身份证(正面)' } },
|
||||
{ label: "身份证(反面)", prop: "reverseCard", rules: { required: v.isAdd, message: '请上传 身份证(反面)' } },
|
||||
{ label: "营业执照", prop: "businessPic", rules: { required: v.isAdd, message: '请上传 营业执照' } },
|
||||
{ label: "畜禽经营许可证", prop: "breedPic", rules: { required: v.isAdd, message: '请上传 畜禽经营许可证' } },
|
||||
{ label: "动物防疫条件许可证", prop: "prevention", rules: { required: v.isAdd, message: '请上传 动物防疫条件许可证' } },
|
||||
]
|
||||
},
|
||||
methods: {
|
||||
@@ -46,21 +48,22 @@ export default {
|
||||
this.$router.push(params)
|
||||
},
|
||||
getDetail() {
|
||||
const {id} = this.$route.query
|
||||
return id && this.instance.post("/api/insurance/apply/getInfo", null, {params: {id}}).then(res => {
|
||||
const { id } = this.$route.query
|
||||
return id ? this.instance.post("/api/insurance/apply/getInfo", null, { params: { id } }).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
detail.detailList = detail.detailList || []
|
||||
let {farmPicture: picture = "{}"} = detail
|
||||
let { farmPicture: picture = "{}" } = detail
|
||||
picture = JSON.parse(picture)
|
||||
return this.detail = {...detail, ...picture}
|
||||
return this.detail = { ...detail, ...picture }
|
||||
}
|
||||
})
|
||||
}) : Promise.resolve()
|
||||
},
|
||||
getCompanies() {
|
||||
this.instance.post("/api/insurance/apply/getCompany").then(res => {
|
||||
if (res?.data) {
|
||||
this.companyList = res.data
|
||||
this.$set(this.detail, "companyId", res.data?.[0]?.id)
|
||||
}
|
||||
})
|
||||
},
|
||||
@@ -70,16 +73,17 @@ export default {
|
||||
},
|
||||
submit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
const earNumberList = this.detail.detailList.map(e => e.biochipEarNumber)
|
||||
const farmPicture = {}
|
||||
this.formImages.forEach(e => {
|
||||
const {prop} = e
|
||||
const { prop } = e
|
||||
const val = this.detail[prop]
|
||||
if (val) {
|
||||
farmPicture[prop] = val
|
||||
}
|
||||
})
|
||||
this.detail.farmPicture = JSON.stringify(farmPicture)
|
||||
this.instance.post("/api/insurance/apply/addOrEditOffline", this.detail).then(res => {
|
||||
this.instance.post("/api/insurance/apply/addOrEditOffline", { ...this.detail, earNumberList }).then(res => {
|
||||
if (res?.code == 0) {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -96,11 +100,21 @@ export default {
|
||||
}
|
||||
})
|
||||
})
|
||||
},
|
||||
getRemoteInfo(userId) {
|
||||
userId && this.instance.post("/api/siteUser/querySiteByUserId", null, {
|
||||
params: { userId }
|
||||
}).then(res => {
|
||||
if (res?.data?.[0]) {
|
||||
const { id } = res.data[0]
|
||||
this.$set(this.detail, "farmId", id)
|
||||
this.$set(this.detail, "targetUser", userId)
|
||||
}
|
||||
})
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.getCompanies()
|
||||
this.getDetail()
|
||||
this.getDetail().finally(() => this.getCompanies())
|
||||
}
|
||||
}
|
||||
</script>
|
||||
@@ -110,51 +124,59 @@ export default {
|
||||
<el-form size="small" label-width="120px" :model="detail" ref="detail">
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid">
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{required:isAdd||isEdit,message:'请选择 养殖场'}">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.farmId" :instance="instance" :action="`/api/siteUser/querySiteByUserId?userId=${userinfo.id}`" :prop="{label:'name'}"/>
|
||||
<b v-else v-text="detail.farmName"/>
|
||||
<el-form-item label="养殖户" class="row">
|
||||
<ai-idcard-remote :instance="instance" @enter="getRemoteInfo" />
|
||||
</el-form-item>
|
||||
<el-form-item label="承保公司" prop="companyId" :rules="{required:isAdd||isEdit,message:'请选择 承保公司'}">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.companyId" :select-list="companyList" :prop="{label:'name'}"/>
|
||||
<b v-else v-text="detail.companyName"/>
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{ required: isAdd || isEdit, message: '请选择 养殖场' }">
|
||||
<ai-select v-if="isAdd || isEdit" v-model="detail.farmId" :instance="instance"
|
||||
:action="`/api/siteUser/querySiteByUserId?userId=${detail.targetUser}`" :prop="{ label: 'name' }" />
|
||||
<b v-else v-text="detail.farmName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="保险产品" prop="productType" :rules="{required:isAdd||isEdit,message:'请选择 保险产品'}">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.productType" :select-list="getProducts(detail.companyId)" :prop="{label:'name',value:'productType'}"
|
||||
@select="v=>$set(detail,'insureType',v.children[0].insureType)"/>
|
||||
<b v-else v-text="detail.productType"/>
|
||||
<el-form-item label="承保公司" prop="companyId" :rules="{ required: isAdd || isEdit, message: '请选择 承保公司' }">
|
||||
<ai-select v-if="isAdd || isEdit" v-model="detail.companyId" :select-list="companyList"
|
||||
:prop="{ label: 'name' }" disabled />
|
||||
<b v-else v-text="detail.companyName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="保险产品" prop="productType" :rules="{ required: isAdd || isEdit, message: '请选择 保险产品' }">
|
||||
<ai-select v-if="isAdd || isEdit" v-model="detail.productType" :select-list="getProducts(detail.companyId)"
|
||||
:prop="{ label: 'name', value: 'productType' }"
|
||||
@select="v => $set(detail, 'insureType', v.children[0].insureType)" />
|
||||
<b v-else v-text="dict.getLabel('productType', detail.productType)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="投保类型">
|
||||
<ai-input :value="dict.getLabel('insureType',detail.insureType)" placeholder="根据保险产品自动带出" :edit="isAdd||isEdit" readonly/>
|
||||
<ai-input :value="dict.getLabel('insureType', detail.insureType)" placeholder="根据保险产品自动带出"
|
||||
:edit="isAdd || isEdit" readonly />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系人">
|
||||
<ai-input v-model="detail.contacts" :edit="isAdd||isEdit"/>
|
||||
<ai-input v-model="detail.contacts" :edit="isAdd || isEdit" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系电话">
|
||||
<ai-input v-model="detail.phone" :edit="isAdd||isEdit"/>
|
||||
<ai-input v-model="detail.phone" :edit="isAdd || isEdit" />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="投保对象">
|
||||
<template #right v-if="isAdd">
|
||||
<ai-eartag-picker @select="v=>detail.detailList=v" :instance="instance"
|
||||
:action="`/api/insurance/apply/getEarNumberList?farmId=${detail.farmId}`">
|
||||
<ai-eartag-picker @select="v => detail.detailList = v" :instance="instance"
|
||||
:action="`/api/insurance/apply/getEarNumberList?farmId=${detail.farmId}`">
|
||||
<el-button type="text">选择</el-button>
|
||||
</ai-eartag-picker>
|
||||
</template>
|
||||
<ai-table :tableData="detail.detailList" :colConfigs="columns" :isShowPagination="!1" hideOptions/>
|
||||
<ai-table :tableData="detail.detailList" :colConfigs="columns" :isShowPagination="!1" hideOptions />
|
||||
</ai-card>
|
||||
<ai-card title="证件信息">
|
||||
<div class="grid c-5 el-form--label-top">
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-if="isAdd||isEdit" v-model="detail[img.prop]" :instance="instance" :limit="1" value-is-url/>
|
||||
<el-image :src="detail[img.prop]" :preview-src-list="[detail[img.prop]]" v-else/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-if="isAdd || isEdit" v-model="detail[img.prop]" :instance="instance" :limit="1"
|
||||
value-is-url />
|
||||
<el-image :src="detail[img.prop]" :preview-src-list="[detail[img.prop]]" v-else />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="审核信息" v-if="!(isAdd||isAudit)">
|
||||
<ai-card title="审核信息" v-if="!(isAdd || isAudit)">
|
||||
<el-form-item label="审核状态">{{ dict.getLabel('auditStatus', detail.auditStatus) }}</el-form-item>
|
||||
<el-form-item label="保单资料" class="sc-4">
|
||||
<el-image :src="detail.picture" :preview-src-list="[detail.picture]"/>
|
||||
<el-image :src="detail.picture" :preview-src-list="[detail.picture]" />
|
||||
</el-form-item>
|
||||
<el-form-item label="审核时间">{{ detail.auditTime }}</el-form-item>
|
||||
<el-form-item label="审核人">{{ detail.auditName }}</el-form-item>
|
||||
@@ -163,20 +185,26 @@ export default {
|
||||
</ai-card>
|
||||
<ai-card title="保险资料" v-if="isAudit">
|
||||
<div class="grid">
|
||||
<el-form-item label="保单订单号" prop="orderNo" :rules="{required:true,message:'请输入 保单订单号'}">
|
||||
<ai-input v-model="detail.orderNo"/>
|
||||
<el-form-item label="审批" prop="auditStatus"
|
||||
:rules="[{ required: true, type: 'enum', enum: [2, 3], message: '请选择是否同意' },]">
|
||||
<ai-audit @change="v => $set(detail, 'auditStatus', v)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="保单资料" class="sc-2">
|
||||
<ai-uploader v-model="detail.picture" value-is-url :instance="instance" :limit="1"/>
|
||||
<el-form-item label="保单资料" class="sc-3">
|
||||
<ai-uploader v-model="detail.picture" value-is-url :instance="instance" :limit="1" />
|
||||
</el-form-item>
|
||||
<el-form-item label="保单订单号" prop="orderNo" :rules="{ required: true, message: '请输入 保单订单号' }"
|
||||
v-if="detail.auditStatus == 2">
|
||||
<ai-input v-model="detail.orderNo" />
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item label="说明">
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remarks"/>
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remarks" />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
</el-form>
|
||||
<div slot="footer">
|
||||
<template v-if="isAdd||isEdit">
|
||||
<template v-if="isAdd || isEdit">
|
||||
<el-button type="primary" @click="submit">提交</el-button>
|
||||
</template>
|
||||
<el-button v-if="isAudit" type="primary" @click="handleAudit">提交</el-button>
|
||||
|
||||
@@ -68,8 +68,8 @@ export default {
|
||||
<ai-select placeholder="全部投保状态" v-model="search.status" dict="insureStatus"/>
|
||||
<ai-select placeholder="全部审批状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="投保日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="养殖户" v-model="search.userName"/>
|
||||
<ai-input placeholder="养殖场" v-model="search.farmName"/>
|
||||
@@ -86,7 +86,7 @@ export default {
|
||||
<el-table-column slot="options" label="操作" fixed="right" align="center">
|
||||
<template slot-scope="{row}">
|
||||
<div class="table-options">
|
||||
<template v-if="['00','02'].includes(row.permit)">
|
||||
<template v-if="['01'].includes(row.permit)">
|
||||
<el-button type="text" @click="$router.push({hash:'#audit',query:{id:row.id}})">审批</el-button>
|
||||
</template>
|
||||
<el-button v-else type="text" @click="$router.push({hash:'#add',query:{id:row.id}})">查看</el-button>
|
||||
|
||||
@@ -1,16 +1,16 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import { mapState } from "vuex"
|
||||
import AiEartagPicker from "@project/xumu/components/AiEartagPicker.vue";
|
||||
|
||||
const columns = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber"},
|
||||
{label: "类别", prop: "category", dict: "category"},
|
||||
{label: "品种", prop: "variety", dict: "variety"},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "生物芯片耳标号", prop: "biochipEarNumber" },
|
||||
{ label: "类别", prop: "category", dict: "category" },
|
||||
{ label: "品种", prop: "variety", dict: "variety" },
|
||||
]
|
||||
export default {
|
||||
name: "loanAdd",
|
||||
components: {AiEartagPicker},
|
||||
components: { AiEartagPicker },
|
||||
props: {
|
||||
instance: Function,
|
||||
permissions: Function,
|
||||
@@ -18,7 +18,7 @@ export default {
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: [], loanAmount: 0},
|
||||
detail: { detailList: [], loanAmount: 0 },
|
||||
columns,
|
||||
bankList: [],
|
||||
filterText: ""
|
||||
@@ -34,11 +34,11 @@ export default {
|
||||
isAdd: v => !v.$route.query.id,
|
||||
isEdit: v => v.$route.query.edit == 1,
|
||||
formImages: v => [
|
||||
{label: "身份证(正面)", prop: "frontCard", rules: {required: v.isAdd || v.isEdit, message: '请上传 身份证(正面)'}},
|
||||
{label: "身份证(反面)", prop: "reverseCard", rules: {required: v.isAdd || v.isEdit, message: '请上传 身份证(反面)'}},
|
||||
{label: "营业执照", prop: "businessPic", rules: {required: v.isAdd || v.isEdit, message: '请上传 营业执照'}},
|
||||
{label: "畜禽经营许可证", prop: "breedPic", rules: {required: v.isAdd || v.isEdit, message: '请上传 畜禽经营许可证'}},
|
||||
{label: "动物防疫条件许可证", prop: "prevention", rules: {required: v.isAdd || v.isEdit, message: '请上传 动物防疫条件许可证'}},
|
||||
{ label: "身份证(正面)", prop: "frontCard", rules: { required: v.isAdd || v.isEdit, message: '请上传 身份证(正面)' } },
|
||||
{ label: "身份证(反面)", prop: "reverseCard", rules: { required: v.isAdd || v.isEdit, message: '请上传 身份证(反面)' } },
|
||||
{ label: "营业执照", prop: "businessPic", rules: { required: v.isAdd || v.isEdit, message: '请上传 营业执照' } },
|
||||
{ label: "畜禽经营许可证", prop: "breedPic", rules: { required: v.isAdd || v.isEdit, message: '请上传 畜禽经营许可证' } },
|
||||
{ label: "动物防疫条件许可证", prop: "prevention", rules: { required: v.isAdd || v.isEdit, message: '请上传 动物防疫条件许可证' } },
|
||||
],
|
||||
selectedEartags: v => v.detail.detailList?.length || 0,
|
||||
tableData: v => v.detail.detailList?.filter(e => e.biochipEarNumber.indexOf(v.filterText) > -1) || [],
|
||||
@@ -48,14 +48,14 @@ export default {
|
||||
this.$router.push(params)
|
||||
},
|
||||
getDetail() {
|
||||
const {id} = this.$route.query
|
||||
return id && this.instance.post("/api/loan/apply/getInfo", null, {params: {id}}).then(res => {
|
||||
const { id } = this.$route.query
|
||||
return id && this.instance.post("/api/loan/apply/getInfo", null, { params: { id } }).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
detail.detailList = detail.detailList || []
|
||||
let {farmPicture: picture = "{}"} = detail
|
||||
let { farmPicture: picture = "{}" } = detail
|
||||
picture = JSON.parse(picture)
|
||||
return this.detail = {...detail, ...picture}
|
||||
return this.detail = { ...detail, ...picture }
|
||||
}
|
||||
})
|
||||
},
|
||||
@@ -72,16 +72,17 @@ export default {
|
||||
},
|
||||
submit(submitType) {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
const earNumberList = this.detail.detailList.map(e => e.biochipEarNumber)
|
||||
const farmPicture = {}
|
||||
this.formImages.forEach(e => {
|
||||
const {prop} = e
|
||||
const { prop } = e
|
||||
const val = this.detail[prop]
|
||||
if (val) {
|
||||
farmPicture[prop] = val
|
||||
}
|
||||
})
|
||||
this.detail.farmPicture = JSON.stringify(farmPicture)
|
||||
this.instance.post("/api/loan/apply/addOrEdit", {...this.detail, submitType}).then(res => {
|
||||
this.instance.post("/api/loan/apply/addOrEdit", { ...this.detail, submitType, earNumberList }).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -102,63 +103,64 @@ export default {
|
||||
<el-form size="small" label-width="120px" :model="detail" ref="detail">
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid">
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{required: isAdd||isEdit,message:'请选择 养殖场'}">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.farmId" :instance="instance" :action="`/api/siteUser/querySiteByUserId?userId=${userinfo.id}`" :prop="{label:'name'}"/>
|
||||
<b v-else v-text="detail.farmName"/>
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{ required: isAdd || isEdit, message: '请选择 养殖场' }">
|
||||
<ai-select v-if="isAdd || isEdit" v-model="detail.farmId" :instance="instance"
|
||||
:action="`/api/siteUser/querySiteByUserId?userId=${userinfo.id}`" :prop="{ label: 'name' }" />
|
||||
<b v-else v-text="detail.farmName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款银行" prop="bankId" :rules="{required: isAdd||isEdit,message:'请选择 贷款银行'}">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.bankId" :select-list="bankList" :prop="{label:'name'}"/>
|
||||
<b v-else v-text="detail.bankName"/>
|
||||
<el-form-item label="贷款银行" prop="bankId" :rules="{ required: isAdd || isEdit, message: '请选择 贷款银行' }">
|
||||
<ai-select v-if="isAdd || isEdit" v-model="detail.bankId" :select-list="bankList" :prop="{ label: 'name' }" />
|
||||
<b v-else v-text="detail.bankName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款产品" prop="productType" :rules="{required: isAdd||isEdit,message:'请选择 贷款产品'}">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.productType"
|
||||
:select-list="getProducts(detail.bankId)" :prop="{label:'name',value:'productType'}"/>
|
||||
<b v-else v-text="dict.getLabel('loanProduct',detail.productType)"/>
|
||||
<el-form-item label="贷款产品" prop="productType" :rules="{ required: isAdd || isEdit, message: '请选择 贷款产品' }">
|
||||
<ai-select v-if="isAdd || isEdit" v-model="detail.productType" :select-list="getProducts(detail.bankId)"
|
||||
:prop="{ label: 'name', value: 'productType' }" />
|
||||
<b v-else v-text="dict.getLabel('loanProduct', detail.productType)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="预期贷款额(万)" prop="loanAmount" :rules="{required: isAdd||isEdit,message:'请输入 预期贷款额'}">
|
||||
<ai-input v-model.number="detail.loanAmount" :edit="isAdd||isEdit"/>
|
||||
<el-form-item label="预期贷款额(万)" prop="loanAmount" :rules="{ required: isAdd || isEdit, message: '请输入 预期贷款额' }">
|
||||
<ai-input v-model.number="detail.loanAmount" :edit="isAdd || isEdit" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系人" prop="contacts" :rules="{required: isAdd||isEdit,message:'请输入 联系人'}">
|
||||
<ai-input v-model="detail.contacts" :edit="isAdd||isEdit"/>
|
||||
<el-form-item label="联系人" prop="contacts" :rules="{ required: isAdd || isEdit, message: '请输入 联系人' }">
|
||||
<ai-input v-model="detail.contacts" :edit="isAdd || isEdit" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系电话" prop="phone" :rules="{required: isAdd||isEdit,message:'请输入 联系电话'}">
|
||||
<ai-input v-model="detail.phone" :edit="isAdd||isEdit"/>
|
||||
<el-form-item label="联系电话" prop="phone" :rules="{ required: isAdd || isEdit, message: '请输入 联系电话' }">
|
||||
<ai-input v-model="detail.phone" :edit="isAdd || isEdit" />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="质押标的">
|
||||
<template #right>
|
||||
<ai-input placeholder="请输入/扫描耳标号" v-model="filterText" class="shrink"/>
|
||||
<ai-eartag-picker @select="v=>detail.detailList=v" :instance="instance" v-if="isAdd||isEdit"
|
||||
:action="`/api/insurance/apply/getEarNumberList?farmId=${detail.farmId}`">
|
||||
<ai-input placeholder="请输入/扫描耳标号" v-model="filterText" class="shrink" />
|
||||
<ai-eartag-picker @select="v => detail.detailList = v" :instance="instance" v-if="isAdd || isEdit"
|
||||
value-key="biochipEarNumber" :action="`/api/insurance/apply/getEarNumberList?farmId=${detail.farmId}`">
|
||||
<el-button type="text">选择</el-button>
|
||||
</ai-eartag-picker>
|
||||
</template>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`拟抵押标的选择 @v 只`" color="red" :value="selectedEartags"/>
|
||||
<ai-table :tableData="tableData" :colConfigs="columns" :isShowPagination="!1" hideOptions/>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`拟抵押标的选择 @v 只`" color="red" :value="selectedEartags" />
|
||||
<ai-table :tableData="tableData" :colConfigs="columns" :isShowPagination="!1" hideOptions />
|
||||
</ai-card>
|
||||
<ai-card title="证件信息">
|
||||
<div v-if="isAdd||isEdit" class="font-12 color-888">只能上传JPG/PNG文件,且不超过2M</div>
|
||||
<div v-if="isAdd || isEdit" class="font-12 color-888">只能上传JPG/PNG文件,且不超过2M</div>
|
||||
<div class="grid c-5 el-form--label-top">
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-if="isAdd||isEdit" v-model="detail[img.prop]" :instance="instance" :limit="1" value-is-url/>
|
||||
<el-image :src="detail[img.prop]" :preview-src-list="[detail[img.prop]]" v-else/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-if="isAdd || isEdit" v-model="detail[img.prop]" :instance="instance" :limit="1" value-is-url />
|
||||
<el-image :src="detail[img.prop]" :preview-src-list="[detail[img.prop]]" v-else />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="审核信息" v-if="!(isAdd||isEdit)">
|
||||
<ai-card title="审核信息" v-if="!(isAdd || isEdit)">
|
||||
<el-form-item label="审核状态">{{ dict.getLabel('auditStatus', detail.auditStatus) }}</el-form-item>
|
||||
<el-form-item label="审核时间">{{ detail.auditTime }}</el-form-item>
|
||||
<el-form-item label="审核人">{{ detail.auditName }}</el-form-item>
|
||||
<el-form-item label="贷款合同号">{{ detail.contractNo || "-" }}</el-form-item>
|
||||
<el-form-item label="贷款资料">
|
||||
<el-image :src="detail.picture" :preview-src-list="[detail.picture]"/>
|
||||
<el-image :src="detail.picture" :preview-src-list="[detail.picture]" />
|
||||
</el-form-item>
|
||||
<el-form-item label="说明">{{ detail.remarks }}</el-form-item>
|
||||
</ai-card>
|
||||
</el-form>
|
||||
<div slot="footer">
|
||||
<template v-if="isAdd||isEdit">
|
||||
<template v-if="isAdd || isEdit">
|
||||
<el-button type="primary" @click="submit(1)">保存草稿</el-button>
|
||||
<el-button type="primary" @click="submit(2)">保存并提交</el-button>
|
||||
</template>
|
||||
|
||||
@@ -77,8 +77,8 @@ export default {
|
||||
<ai-select placeholder="全部贷款状态" v-model="search.status" dict="loanStatus"/>
|
||||
<ai-select placeholder="全部审批状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="贷款日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="养殖户" v-model="search.applyName"/>
|
||||
<ai-input placeholder="养殖场" v-model="search.farmName"/>
|
||||
|
||||
@@ -1,17 +1,19 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import { mapState } from "vuex"
|
||||
import AiEartagPicker from "@project/xumu/components/AiEartagPicker.vue";
|
||||
import AiIdcardRemote from "@project/xumu/components/AiIdcardRemote.vue";
|
||||
import AiAudit from "../components/AiAudit.vue";
|
||||
|
||||
const records = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "报案号", prop: "reportNo"},
|
||||
{label: "审批状态", prop: "auditStatus", dict: "auditStatus"},
|
||||
{label: "审批时间", prop: "auditTime"},
|
||||
{label: "审批人", prop: "auditName"},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "报案号", prop: "reportNo" },
|
||||
{ label: "审批状态", prop: "auditStatus", dict: "auditStatus" },
|
||||
{ label: "审批时间", prop: "auditTime" },
|
||||
{ label: "审批人", prop: "auditName" },
|
||||
]
|
||||
export default {
|
||||
name: "loanAdd",
|
||||
components: {AiEartagPicker},
|
||||
components: { AiIdcardRemote, AiEartagPicker, AiAudit },
|
||||
props: {
|
||||
instance: Function,
|
||||
permissions: Function,
|
||||
@@ -19,7 +21,7 @@ export default {
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: []},
|
||||
detail: { detailList: [] },
|
||||
records,
|
||||
filterText: "",
|
||||
bankList: []
|
||||
@@ -35,17 +37,17 @@ export default {
|
||||
isAdd: v => !v.$route.query.id,
|
||||
isAudit: v => v.$route.hash == "#audit",
|
||||
formImages: v => [
|
||||
{label: "身份证(正面)", prop: "frontCard", rules: {required: v.isAdd, message: '请上传 身份证(正面)'}},
|
||||
{label: "身份证(反面)", prop: "reverseCard", rules: {required: v.isAdd, message: '请上传 身份证(反面)'}},
|
||||
{label: "营业执照", prop: "businessPic", rules: {required: v.isAdd, message: '请上传 营业执照'}},
|
||||
{label: "畜禽经营许可证", prop: "breedPic", rules: {required: v.isAdd, message: '请上传 畜禽经营许可证'}},
|
||||
{label: "动物防疫条件许可证", prop: "prevention", rules: {required: v.isAdd, message: '请上传 动物防疫条件许可证'}},
|
||||
{ label: "身份证(正面)", prop: "frontCard", rules: { required: v.isAdd, message: '请上传 身份证(正面)' } },
|
||||
{ label: "身份证(反面)", prop: "reverseCard", rules: { required: v.isAdd, message: '请上传 身份证(反面)' } },
|
||||
{ label: "营业执照", prop: "businessPic", rules: { required: v.isAdd, message: '请上传 营业执照' } },
|
||||
{ label: "畜禽经营许可证", prop: "breedPic", rules: { required: v.isAdd, message: '请上传 畜禽经营许可证' } },
|
||||
{ label: "动物防疫条件许可证", prop: "prevention", rules: { required: v.isAdd, message: '请上传 动物防疫条件许可证' } },
|
||||
],
|
||||
columns: v => [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber"},
|
||||
{label: "类别", prop: "category", dict: "category"},
|
||||
{label: "品种", prop: "variety", dict: "variety"}
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "生物芯片耳标号", prop: "biochipEarNumber" },
|
||||
{ label: "类别", prop: "category", dict: "category" },
|
||||
{ label: "品种", prop: "variety", dict: "variety" }
|
||||
].filter(e => !e.hide),
|
||||
selectedEartags: v => v.detail.detailList?.length || 0,
|
||||
tableData: v => v.detail.detailList?.filter(e => e.biochipEarNumber.indexOf(v.filterText) > -1) || [],
|
||||
@@ -55,29 +57,29 @@ export default {
|
||||
this.$router.push(params)
|
||||
},
|
||||
getDetail() {
|
||||
const {id} = this.$route.query
|
||||
return id && this.instance.post("/api/loan/apply/getInfo", null, {params: {id}}).then(res => {
|
||||
const { id } = this.$route.query
|
||||
return id ? this.instance.post("/api/loan/apply/getInfo", null, { params: { id } }).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
detail.detailList = detail.detailList || []
|
||||
let {farmPicture: picture} = detail
|
||||
let { farmPicture: picture } = detail
|
||||
picture = JSON.parse(picture || "{}")
|
||||
return this.detail = {...detail, ...picture}
|
||||
return this.detail = { ...detail, ...picture }
|
||||
}
|
||||
})
|
||||
}) : Promise.resolve()
|
||||
},
|
||||
submit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
const farmPicture = {}
|
||||
this.formImages.forEach(e => {
|
||||
const {prop} = e
|
||||
const { prop } = e
|
||||
const val = this.detail[prop]
|
||||
if (val) {
|
||||
farmPicture[prop] = val
|
||||
}
|
||||
})
|
||||
this.detail.farmPicture = JSON.stringify(farmPicture)
|
||||
this.instance.post("/api/loan/apply/addOrEditOffline", {...this.detail}).then(res => {
|
||||
this.instance.post("/api/loan/apply/addOrEditOffline", { ...this.detail }).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -87,7 +89,7 @@ export default {
|
||||
},
|
||||
audit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
this.instance.post("/api/loan/apply/audit", {...this.detail}).then(res => {
|
||||
this.instance.post("/api/loan/apply/audit", { ...this.detail }).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -99,6 +101,7 @@ export default {
|
||||
this.instance.post("/api/loan/apply/getBank").then(res => {
|
||||
if (res?.data) {
|
||||
this.bankList = res.data
|
||||
this.$set(this.detail, "bankId", res.data?.[0]?.id)
|
||||
}
|
||||
})
|
||||
},
|
||||
@@ -106,10 +109,18 @@ export default {
|
||||
const item = this.bankList.find(e => e.id == id)
|
||||
return item?.children || []
|
||||
},
|
||||
getRemoteInfo(userId) {
|
||||
userId && this.instance.post("/api/siteUser/querySiteByUserId", null, {
|
||||
params: { userId }
|
||||
}).then(res => {
|
||||
if (res?.data) {
|
||||
this.$set(this.detail, "farmId", res.data?.[0]?.id)
|
||||
}
|
||||
})
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.getBanks()
|
||||
this.getDetail()
|
||||
this.getDetail().finally(() => this.getBanks())
|
||||
}
|
||||
}
|
||||
</script>
|
||||
@@ -119,76 +130,82 @@ export default {
|
||||
<el-form size="small" label-width="120px" :model="detail" ref="detail">
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid">
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{required: isAdd,message:'请选择 养殖场'}">
|
||||
<ai-select v-if="isAdd" v-model="detail.farmId" :instance="instance" :action="`/api/siteUser/querySiteByUserId?userId=${userinfo.id}`" :prop="{label:'name'}"/>
|
||||
<b v-else v-text="detail.farmName"/>
|
||||
<el-form-item label="养殖户" class="row">
|
||||
<ai-idcard-remote :instance="instance" @enter="getRemoteInfo" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款银行" prop="bankId" :rules="{required: isAdd,message:'请选择 贷款银行'}">
|
||||
<ai-select v-if="isAdd" v-model="detail.bankId" :select-list="bankList" :prop="{label:'name'}"/>
|
||||
<b v-else v-text="detail.bankName"/>
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{ required: isAdd, message: '请选择 养殖场' }">
|
||||
<ai-select v-if="isAdd" v-model="detail.farmId" :instance="instance"
|
||||
:action="`/api/siteUser/querySiteByUserId?userId=${userinfo.id}`" :prop="{ label: 'name' }" />
|
||||
<b v-else v-text="detail.farmName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款产品" prop="productType" :rules="{required: isAdd,message:'请选择 贷款产品'}">
|
||||
<ai-select v-if="isAdd" v-model="detail.productType"
|
||||
:select-list="getProducts(detail.bankId)" :prop="{label:'name',value:'productType'}"/>
|
||||
<b v-else v-text="dict.getLabel('loanProduct',detail.productType)"/>
|
||||
<el-form-item label="贷款银行" prop="bankId" :rules="{ required: isAdd, message: '请选择 贷款银行' }">
|
||||
<ai-select v-if="isAdd" v-model="detail.bankId" :select-list="bankList" :prop="{ label: 'name' }"
|
||||
disabled />
|
||||
<b v-else v-text="detail.bankName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="预期贷款额(万)" prop="loanAmount" :rules="{required: isAdd,message:'请输入 预期贷款额'}">
|
||||
<ai-input v-model.number="detail.loanAmount" :edit="isAdd"/>
|
||||
<el-form-item label="贷款产品" prop="productType" :rules="{ required: isAdd, message: '请选择 贷款产品' }">
|
||||
<ai-select v-if="isAdd" v-model="detail.productType" :select-list="getProducts(detail.bankId)"
|
||||
:prop="{ label: 'name', value: 'productType' }" />
|
||||
<b v-else v-text="dict.getLabel('loanProduct', detail.productType)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系人" prop="contacts" :rules="{required: isAdd,message:'请输入 联系人'}">
|
||||
<ai-input v-model="detail.contacts" :edit="isAdd"/>
|
||||
<el-form-item label="预期贷款额(万)" prop="loanAmount" :rules="{ required: isAdd, message: '请输入 预期贷款额' }">
|
||||
<ai-input v-model.number="detail.loanAmount" :edit="isAdd" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系电话" prop="phone" :rules="{required: isAdd,message:'请输入 联系电话'}">
|
||||
<ai-input v-model="detail.phone" :edit="isAdd"/>
|
||||
<el-form-item label="联系人" prop="contacts" :rules="{ required: isAdd, message: '请输入 联系人' }">
|
||||
<ai-input v-model="detail.contacts" :edit="isAdd" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系电话" prop="phone" :rules="{ required: isAdd, message: '请输入 联系电话' }">
|
||||
<ai-input v-model="detail.phone" :edit="isAdd" />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="质押标的">
|
||||
<template #right>
|
||||
<ai-input placeholder="请输入/扫描耳标号" v-model="filterText" class="shrink"/>
|
||||
<ai-eartag-picker @select="v=>detail.detailList=v" :instance="instance" v-if="isAdd"
|
||||
:action="`/api/insurance/apply/getEarNumberList?farmId=${detail.farmId}`">
|
||||
<ai-input placeholder="请输入/扫描耳标号" v-model="filterText" class="shrink" />
|
||||
<ai-eartag-picker @select="v => detail.detailList = v" :instance="instance" v-if="isAdd"
|
||||
:action="`/api/insurance/apply/getEarNumberList?farmId=${detail.farmId}`">
|
||||
<el-button type="text">选择</el-button>
|
||||
</ai-eartag-picker>
|
||||
</template>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`拟抵押标的选择 @v 只`" color="red" :value="selectedEartags"/>
|
||||
<ai-table :tableData="tableData" :colConfigs="columns" :isShowPagination="!1" hideOptions/>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`拟抵押标的选择 @v 只`" color="red" :value="selectedEartags" />
|
||||
<ai-table :tableData="tableData" :colConfigs="columns" :isShowPagination="!1" hideOptions />
|
||||
</ai-card>
|
||||
<ai-card title="证件信息">
|
||||
<div v-if="isAdd" class="font-12 color-888">只能上传JPG/PNG文件,且不超过2M</div>
|
||||
<div class="grid c-5 el-form--label-top">
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader :readonly="!isAdd" v-model="detail[img.prop]" :instance="instance" :limit="1" value-is-url/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader :readonly="!isAdd" v-model="detail[img.prop]" :instance="instance" :limit="1" value-is-url />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="银行资料" v-if="isAdd">
|
||||
<div class="grid">
|
||||
<el-form-item label="贷款合同号" prop="contractNo" :rules="{required:true,message:'请输入贷款合同号'}">
|
||||
<ai-input v-model="detail.contractNo"/>
|
||||
<el-form-item label="贷款合同号" prop="contractNo" :rules="{ required: true, message: '请输入贷款合同号' }">
|
||||
<ai-input v-model="detail.contractNo" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款资料" class="sc-2">
|
||||
<ai-uploader v-model="detail.picture" value-is-url :instance="instance" :limit="1"/>
|
||||
<ai-uploader v-model="detail.picture" value-is-url :instance="instance" :limit="1" />
|
||||
</el-form-item>
|
||||
<el-form-item label="说明">
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remarks"/>
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remarks" />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="审核信息" v-if="!isAdd">
|
||||
<div class="grid">
|
||||
<template v-if="isAudit">
|
||||
<el-form-item label="审批状态" prop="auditStatus" :rules="{required:true,message:'请选择审批状态'}">
|
||||
<ai-select v-model="detail.auditStatus" dict="auditStatus"/>
|
||||
<el-form-item label="审批状态" prop="auditStatus" :rules="{ required: true, message: '请选择审批状态' }">
|
||||
<ai-audit @change="v => $set(detail, 'auditStatus', v)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款资料" class="sc-3">
|
||||
<ai-uploader v-model="detail.picture" value-is-url :instance="instance" :limit="1"/>
|
||||
<ai-uploader v-model="detail.picture" value-is-url :instance="instance" :limit="1" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款合同号" prop="contractNo" :rules="{required:true,message:'请输入 报案号'}">
|
||||
<ai-input v-model="detail.contractNo"/>
|
||||
<el-form-item label="贷款合同号" prop="contractNo"
|
||||
:rules="{ required: detail.auditStatus == 2, message: '请输入 报案号' }">
|
||||
<ai-input v-model="detail.contractNo" />
|
||||
</el-form-item>
|
||||
<el-form-item label="说明">
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remarks"/>
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remarks" />
|
||||
</el-form-item>
|
||||
</template>
|
||||
<template v-else>
|
||||
@@ -196,7 +213,7 @@ export default {
|
||||
<el-form-item label="贷款合同号">{{ detail.contractNo }}</el-form-item>
|
||||
<el-form-item label="审核时间">{{ detail.auditTime }}</el-form-item>
|
||||
<el-form-item label="贷款资料" class="sc-3">
|
||||
<el-image :src="detail.picture" :preview-src-list="[detail.picture]"/>
|
||||
<el-image :src="detail.picture" :preview-src-list="[detail.picture]" />
|
||||
</el-form-item>
|
||||
<el-form-item label="审核人">{{ detail.auditName }}</el-form-item>
|
||||
<el-form-item label="说明">{{ detail.remarks }}</el-form-item>
|
||||
|
||||
@@ -68,8 +68,8 @@ export default {
|
||||
<ai-select placeholder="全部贷款状态" v-model="search.status" dict="loanStatus"/>
|
||||
<ai-select placeholder="全部审批状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="贷款日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="养殖户" v-model="search.applyName"/>
|
||||
<ai-input placeholder="养殖场" v-model="search.farmName"/>
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import { mapState } from "vuex"
|
||||
import AiAudit from "../components/AiAudit.vue";
|
||||
|
||||
export default {
|
||||
name: "oaAdd",
|
||||
@@ -8,9 +9,10 @@ export default {
|
||||
permissions: Function,
|
||||
dict: Object
|
||||
},
|
||||
components:{AiAudit},
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: []}
|
||||
detail: { detailList: [] }
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
@@ -22,17 +24,17 @@ export default {
|
||||
},
|
||||
isAudit: v => v.$route.hash == "#audit",
|
||||
formImages: v => [
|
||||
{label: "身长测量照片", prop: "heightPic"},
|
||||
{label: "生物芯片照片", prop: "biochipPic"},
|
||||
{label: "防疫耳标照片", prop: "preventionPic"},
|
||||
{label: "其他说明照片", prop: "otherPic"},
|
||||
{ label: "身长测量照片", prop: "heightPic" },
|
||||
{ label: "生物芯片照片", prop: "biochipPic" },
|
||||
{ label: "防疫耳标照片", prop: "preventionPic" },
|
||||
{ label: "其他说明照片", prop: "otherPic" },
|
||||
],
|
||||
columns: v => [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber"},
|
||||
{label: "身长测量照片", prop: "heightPicture", upload: {instance: v.instance, readonly: !0, valueIsUrl: !0, limit: 1}},
|
||||
{label: "电子耳标照片", prop: "earNumberPicture", upload: {instance: v.instance, readonly: !0, valueIsUrl: !0, limit: 1}},
|
||||
{label: "防疫耳标照片", prop: "preventionPicture", upload: {instance: v.instance, readonly: !0, valueIsUrl: !0, limit: 1}},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "生物芯片耳标号", prop: "biochipEarNumber" },
|
||||
{ label: "身长测量照片", prop: "heightPicture", upload: { instance: v.instance, readonly: !0, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "电子耳标照片", prop: "earNumberPicture", upload: { instance: v.instance, readonly: !0, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "防疫耳标照片", prop: "preventionPicture", upload: { instance: v.instance, readonly: !0, valueIsUrl: !0, limit: 1 } },
|
||||
].filter(e => !e.hide),
|
||||
},
|
||||
methods: {
|
||||
@@ -40,17 +42,17 @@ export default {
|
||||
this.$router.push(params)
|
||||
},
|
||||
getDetail() {
|
||||
const {id} = this.$route.query
|
||||
return id && this.instance.post("/api/breed/out/getAuditInfo", null, {params: {id}}).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
return this.detail = {...detail}
|
||||
const { id } = this.$route.query
|
||||
return id && this.instance.post("/api/breed/out/getAuditPage", { id }).then(res => {
|
||||
if (res?.data?.records?.[0]) {
|
||||
const detail = res.data.records[0] || {}
|
||||
return this.detail = { ...detail }
|
||||
}
|
||||
})
|
||||
},
|
||||
submit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
this.instance.post("/api/breed/out/audit", {...this.detail}).then(res => {
|
||||
this.instance.post("/api/breed/out/audit", { ...this.detail }).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -71,55 +73,55 @@ export default {
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid c-4">
|
||||
<el-form-item label="生物芯片耳标号" class="row">
|
||||
<b v-text="detail.biochipEarNumber"/>
|
||||
<b v-text="detail.biochipEarNumber" />
|
||||
</el-form-item>
|
||||
<el-form-item label="养殖场" prop="farmId">
|
||||
<b v-text="detail.farmName"/>
|
||||
<b v-text="detail.farmName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="养殖舍" prop="houseId">
|
||||
<b v-text="detail.houseName"/>
|
||||
<b v-text="detail.houseName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="养殖栏" prop="penId">
|
||||
<b v-text="detail.penName"/>
|
||||
<b v-text="detail.penName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="电子耳标号" prop="electronicEarNumber">
|
||||
<b v-text="detail.electronicEarNumber"/>
|
||||
<b v-text="detail.electronicEarNumber" />
|
||||
</el-form-item>
|
||||
<el-form-item label="原厂耳标号" prop="category">
|
||||
<b v-text="detail.originalEarNumber"/>
|
||||
<b v-text="detail.originalEarNumber" />
|
||||
</el-form-item>
|
||||
<el-form-item label="类别" prop="category">
|
||||
<b v-text="detail.category"/>
|
||||
<b v-text="dict.getLabel('category',detail.category)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="品种" prop="variety">
|
||||
<b v-text="detail.variety"/>
|
||||
<b v-text="dict.getLabel('variety',detail.variety)" />
|
||||
</el-form-item>
|
||||
<div class="row flex">
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" value-is-url readonly/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" value-is-url readonly />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="淘汰信息">
|
||||
<el-form-item label="淘汰原因">
|
||||
<b v-text="dict.getLabel('outReason',detail.reason)"/>
|
||||
<b v-text="dict.getLabel('outReason', detail.reason)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="淘汰时间">
|
||||
<b v-text="detail.outTime"/>
|
||||
<b v-text="detail.outTime" />
|
||||
</el-form-item>
|
||||
<el-form-item label="备注">
|
||||
<b v-text="detail.remark"/>
|
||||
<b v-text="detail.remark" />
|
||||
</el-form-item>
|
||||
</ai-card>
|
||||
<ai-card title="审核信息">
|
||||
<div class="grid">
|
||||
<template v-if="isAudit">
|
||||
<el-form-item label="审批状态" prop="auditStatus" :rules="{required:true,message:'请选择审批状态'}">
|
||||
<ai-select v-model="detail.auditStatus" dict="auditStatus"/>
|
||||
<el-form-item label="审批状态" prop="auditStatus" :rules="{ required: true, message: '请选择审批状态' }">
|
||||
<ai-audit @change="v => $set(detail, 'auditStatus', v)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="意见">
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remark"/>
|
||||
<ai-input type="textarea" :rows="3" v-model="detail.remark" />
|
||||
</el-form-item>
|
||||
</template>
|
||||
<template v-else>
|
||||
|
||||
@@ -68,12 +68,12 @@ export default {
|
||||
<ai-select placeholder="全部养殖栏" v-model="search.penId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.houseId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-select placeholder="全部审核状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="淘汰日期">
|
||||
<el-date-picker v-model="search.outBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.outEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.outBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.outEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-search label="登记日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="原场耳标号" v-model="search.originalEarNumber"/>
|
||||
<ai-input placeholder="生物芯片耳标号" v-model="search.biochipEarNumber"/>
|
||||
|
||||
@@ -1,14 +1,16 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import AiEartagRemote from "@project/xumu/components/AiEartagRemote.vue";
|
||||
|
||||
const formImages = [
|
||||
{label: "身长测量照片", prop: "heightPic", rules: {required: true, message: '请上传 身长测量照片'}},
|
||||
{label: "生物芯片照片", prop: "biochipPic", rules: {required: true, message: '请上传 生物芯片照片'}},
|
||||
{label: "防疫耳标照片", prop: "preventionPic", rules: {required: true, message: '请上传 防疫耳标照片'}},
|
||||
{label: "其他说明照片", prop: "otherPic", rules: {required: true, message: '请上传 其他说明照片'}},
|
||||
{label: "身长测量照片", prop: "heightPic",},
|
||||
{label: "生物芯片照片", prop: "biochipPic",},
|
||||
{label: "防疫耳标照片", prop: "preventionPic",},
|
||||
{label: "其他说明照片", prop: "otherPic",},
|
||||
]
|
||||
export default {
|
||||
name: "outAdd",
|
||||
components: {AiEartagRemote},
|
||||
props: {
|
||||
instance: Function,
|
||||
permissions: Function,
|
||||
@@ -54,7 +56,7 @@ export default {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
const {biochipEarNumber, id, outTime, heightPic, biochipPic, preventionPic, otherPic, reason, remarks} = this.detail
|
||||
this.instance.post("/api/breed/out/addOrEdit", {
|
||||
biochipEarNumber, id, outTime, picture: {heightPic, biochipPic, preventionPic, otherPic}, reason, remarks
|
||||
biochipEarNumber, id, outTime, picture: JSON.stringify({heightPic, biochipPic, preventionPic, otherPic}), reason, remarks
|
||||
}).then(res => {
|
||||
if (res?.code == 0 && res?.data != 1) {
|
||||
this.$confirm("是否返回列表页?", "提交成功").then(() => this.back()).catch(() => this.getDetail(biochipEarNumber))
|
||||
@@ -72,7 +74,10 @@ export default {
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
},
|
||||
handlerAutocomplete(value) {
|
||||
'biochipEarNumber|farmId|houseId|penId|electronicEarNumber|originalEarNumber|category|variety'.split("|").forEach(prop => this.$set(this.detail, prop, value[prop]))
|
||||
},
|
||||
},
|
||||
created() {
|
||||
this.dict.load("yesOrNo", "category", "variety", "outReason")
|
||||
@@ -86,7 +91,7 @@ export default {
|
||||
<el-form size="small" label-width="120px" :model="detail" ref="detail">
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid c-4">
|
||||
<ai-input class="row" v-model="filter" placeholder="请输入耳标号按回车查询,或扫描耳标号" @keyup.enter.native="getDetail(filter)"/>
|
||||
<ai-eartag-remote :instance="instance" @enter="handlerAutocomplete" class="row"/>
|
||||
<el-form-item label="生物芯片耳标号">
|
||||
<b v-text="detail.biochipEarNumber"/>
|
||||
</el-form-item>
|
||||
@@ -102,7 +107,7 @@ export default {
|
||||
<el-form-item label="电子耳标号" prop="electronicEarNumber">
|
||||
<b v-text="detail.electronicEarNumber"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="原厂耳标号" prop="category">
|
||||
<el-form-item label="原厂耳标号" prop="originalEarNumber">
|
||||
<b v-text="detail.originalEarNumber"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="类别" prop="category">
|
||||
@@ -115,31 +120,32 @@ export default {
|
||||
</ai-card>
|
||||
<ai-card title="上传照片">
|
||||
<div class="grid c-4">
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-if="isAdd||isEdit" v-model="detail[img.prop]" :instance="instance" :limit="1" value-is-url/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-if="isAdd || isEdit" v-model="detail[img.prop]" :instance="instance" :limit="1" value-is-url/>
|
||||
<el-image :src="detail[img.prop]" :preview-src-list="[detail[img.prop]]" v-else/>
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="淘汰录入">
|
||||
<div class="grid">
|
||||
<el-form-item label="淘汰日期" prop="outTime" :rules="[{required:true,message:'请选择淘汰日期'}]">
|
||||
<el-date-picker v-if="isAdd||isEdit" v-model="detail.outTime"/>
|
||||
<b v-text="detail.outTime"/>
|
||||
<el-form-item label="淘汰日期" prop="outTime" :rules="[{ required: true, message: '请选择淘汰日期' }]">
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-if="isAdd || isEdit" v-model="detail.outTime"/>
|
||||
<b v-else v-text="detail.outTime"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="淘汰原因" prop="reason" :rules="[{required:true,message:'请选择淘汰原因'}]">
|
||||
<ai-select v-if="isAdd||isEdit" v-model="detail.reason" dict="outReason"/>
|
||||
<b v-text="detail.reason"/>
|
||||
<el-form-item label="淘汰原因" prop="reason" :rules="[{ required: true, message: '请选择淘汰原因' }]">
|
||||
<ai-select v-if="isAdd || isEdit" v-model="detail.reason" dict="outReason"/>
|
||||
<b v-else v-text="detail.reason"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="备注" prop="remark" class="row">
|
||||
<ai-input type="textarea" :row="3" v-model="detail.remark" :edit="isAdd||isEdit"/>
|
||||
<ai-input type="textarea" :row="3" v-model="detail.remark" :edit="isAdd || isEdit"/>
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="审批信息" v-if="isAuthing">
|
||||
<el-form :model="form" size="small" ref="form" label-width="120px">
|
||||
<el-form-item label="是否同意" prop="auditStatus" :rules="[{required:true,message:'请选择是否同意'}]">
|
||||
<ai-select v-model="form.auditStatus" :select-list="[{dictValue: 2, dictName: '同意'}, {dictValue: 3, dictName: '不同意'}]"/>
|
||||
<el-form-item label="是否同意" prop="auditStatus" :rules="[{ required: true, message: '请选择是否同意' }]">
|
||||
<ai-select v-model="form.auditStatus"
|
||||
:select-list="[{ dictValue: 2, dictName: '同意' }, { dictValue: 3, dictName: '不同意' }]"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="审批意见" prop="auditReason">
|
||||
<el-input type="textarea" :row="3" v-model="form.auditReason" clearable placeholder="请输入"/>
|
||||
@@ -148,7 +154,7 @@ export default {
|
||||
</ai-card>
|
||||
</el-form>
|
||||
<div slot="footer">
|
||||
<el-button type="primary" @click="submit" v-if="isAdd||isEdit">提交</el-button>
|
||||
<el-button type="primary" @click="submit" v-if="isAdd || isEdit">提交</el-button>
|
||||
<el-button type="primary" @click="handleAudit" v-if="isAuthing">提交</el-button>
|
||||
<el-button @click="back">返回</el-button>
|
||||
</div>
|
||||
|
||||
@@ -94,12 +94,12 @@ export default {
|
||||
<ai-select placeholder="全部养殖栏" v-model="search.penId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.houseId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-select placeholder="全部审核状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="淘汰日期">
|
||||
<el-date-picker v-model="search.outBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.outEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.outBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.outEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-search label="登记日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="原场耳标号" v-model="search.originalEarNumber"/>
|
||||
<ai-input placeholder="生物芯片耳标号" v-model="search.biochipEarNumber"/>
|
||||
|
||||
@@ -35,23 +35,12 @@
|
||||
@getList="getTableData" :col-configs="colConfigs" :dict="dict"
|
||||
@selection-change="v=>multipleSelection=v">
|
||||
<el-table-column label="角色用户" slot="users" align="center">
|
||||
<template slot-scope="scope">
|
||||
<el-tooltip
|
||||
effect="light"
|
||||
placement="top"
|
||||
:disabled="scope.row.users.length <= 2"
|
||||
content="更多角色用户请点击详情按钮">
|
||||
<span v-if="scope.row.users.length">
|
||||
{{
|
||||
scope.row.users
|
||||
.slice(0, 2)
|
||||
.map((e) => e.name + "(" + e.phone + ")")
|
||||
.join(";")
|
||||
}}
|
||||
<span v-if="scope.row.users.length > 2">...</span>
|
||||
</span>
|
||||
<span v-else>-</span>
|
||||
</el-tooltip>
|
||||
<template slot-scope="{row}">
|
||||
<div class="font-12 flex wrap gap-6">
|
||||
<el-tag size="mini" v-for="(item, i) in row.users" :key="i">{{ item.name }}
|
||||
<template v-if="item.phone">({{ item.phone }})</template>
|
||||
</el-tag>
|
||||
</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column slot="options" label="操作" fixed="right" align="center">
|
||||
@@ -186,7 +175,7 @@ export default {
|
||||
colConfigs() {
|
||||
return [
|
||||
{type: "selection"},
|
||||
{label: "角色名", prop: "name", width: '100px'},
|
||||
{label: "角色名", prop: "name", width: 140},
|
||||
{label: "所属端", prop: "type", width: '100px', dict: "roleType"},
|
||||
{label: "用户数量", prop: "roleCount", align: 'center', width: '80px'},
|
||||
{slot: "users"},
|
||||
@@ -248,7 +237,8 @@ export default {
|
||||
hash: "#add",
|
||||
query: {
|
||||
id: item.id,
|
||||
name: item.name
|
||||
name: item.name,
|
||||
type: item.type,
|
||||
},
|
||||
});
|
||||
},
|
||||
|
||||
@@ -58,7 +58,6 @@ export default {
|
||||
data() {
|
||||
return {
|
||||
form: {},
|
||||
roleName: '',
|
||||
id: '',
|
||||
appList: [],
|
||||
roleList: [],
|
||||
@@ -73,8 +72,8 @@ export default {
|
||||
},
|
||||
created() {
|
||||
if (this.isEdit) {
|
||||
let {id, name: roleName} = this.$route.query
|
||||
this.form = {menus: [], id, roleName}
|
||||
let {id, name: roleName, type} = this.$route.query
|
||||
this.form = {menus: [], id, roleName, type}
|
||||
this.msgTitle = '编辑'
|
||||
}
|
||||
this.getPermissions()
|
||||
|
||||
@@ -1,17 +1,17 @@
|
||||
<script>
|
||||
import {mapState} from "vuex"
|
||||
import { mapState } from "vuex"
|
||||
import AiEartagPicker from "@project/xumu/components/AiEartagPicker.vue";
|
||||
|
||||
const records = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "解押凭证号", prop: "releaseNo"},
|
||||
{label: "审批状态", prop: "auditStatus", dict: "auditStatus"},
|
||||
{label: "审批时间", prop: "auditTime"},
|
||||
{label: "审批人", prop: "auditName"},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "解押凭证号", prop: "releaseNo" },
|
||||
{ label: "审批状态", prop: "auditStatus", dict: "auditStatus" },
|
||||
{ label: "审批时间", prop: "auditTime" },
|
||||
{ label: "审批人", prop: "auditName" },
|
||||
]
|
||||
export default {
|
||||
name: "sellAdd",
|
||||
components: {AiEartagPicker},
|
||||
components: { AiEartagPicker },
|
||||
props: {
|
||||
instance: Function,
|
||||
permissions: Function,
|
||||
@@ -19,7 +19,7 @@ export default {
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
detail: {detailList: []},
|
||||
detail: { detailList: [] },
|
||||
records
|
||||
}
|
||||
},
|
||||
@@ -32,15 +32,15 @@ export default {
|
||||
},
|
||||
isEdit: v => v.$route.hash == "#edit",
|
||||
formImages: v => [
|
||||
{label: "合同/协议", prop: "contractPicture", rules: {required: v.isEdit, message: '请上传 合同/协议'}},
|
||||
{ label: "合同/协议", prop: "contractPicture", rules: { required: v.isEdit, message: '请上传 合同/协议' } },
|
||||
],
|
||||
columns: v => [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "生物芯片耳标号", prop: "biochipEarNumber"},
|
||||
{label: "身长测量照片", prop: "heightPicture", upload: {instance: v.instance, readonly: !v.isEdit, valueIsUrl: !0, limit: 1}},
|
||||
{label: "电子耳标照片", prop: "earNumberPicture", upload: {instance: v.instance, readonly: !v.isEdit, valueIsUrl: !0, limit: 1}},
|
||||
{label: "防疫耳标照片", prop: "preventionPicture", upload: {instance: v.instance, readonly: !v.isEdit, valueIsUrl: !0, limit: 1}},
|
||||
{label: "解押办结凭证号", prop: "releaseNo", hide: v.isEdit},
|
||||
{ label: "序号", type: "index" },
|
||||
{ label: "生物芯片耳标号", prop: "biochipEarNumber" },
|
||||
{ label: "身长测量照片", prop: "heightPicture", upload: { instance: v.instance, readonly: !v.isEdit, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "电子耳标照片", prop: "earNumberPicture", upload: { instance: v.instance, readonly: !v.isEdit, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "防疫耳标照片", prop: "preventionPicture", upload: { instance: v.instance, readonly: !v.isEdit, valueIsUrl: !0, limit: 1 } },
|
||||
{ label: "解押办结凭证号", prop: "releaseNo", hide: v.isEdit },
|
||||
].filter(e => !e.hide),
|
||||
selectedEartags: v => v.detail.list?.length || 0,
|
||||
},
|
||||
@@ -49,19 +49,20 @@ export default {
|
||||
this.$router.push(params)
|
||||
},
|
||||
getDetail() {
|
||||
const {id} = this.$route.query
|
||||
return id && this.instance.post("/api/sell/apply/getInfo", null, {params: {contractNo: id}}).then(res => {
|
||||
const { id } = this.$route.query
|
||||
return id && this.instance.post("/api/sell/apply/getInfo", null, { params: { contractNo: id } }).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
detail.detailList = detail.detailList || []
|
||||
detail.list = detail.list || []
|
||||
return this.detail = {...detail}
|
||||
return this.detail = { ...detail }
|
||||
}
|
||||
})
|
||||
},
|
||||
submit() {
|
||||
this.$refs.detail.validate().then(() => {
|
||||
this.instance.post("/api/sell/apply/add", {...this.detail}).then(res => {
|
||||
const earNumberList = this.detail.detailList.map(e => e.biochipEarNumber)
|
||||
this.instance.post("/api/sell/apply/add", { ...this.detail, earNumberList }).then(res => {
|
||||
if (res?.code == '0') {
|
||||
this.$message.success("提交成功!")
|
||||
this.back()
|
||||
@@ -81,44 +82,45 @@ export default {
|
||||
<el-form size="small" label-width="120px" :model="detail" ref="detail">
|
||||
<ai-card title="基础信息">
|
||||
<div class="grid">
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{message:'请选择 养殖场'}">
|
||||
<b v-text="detail.farmName"/>
|
||||
<el-form-item label="养殖场" prop="farmId" :rules="{ message: '请选择 养殖场' }">
|
||||
<b v-text="detail.farmName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款银行" prop="bankId" :rules="{message:'请选择 贷款银行'}">
|
||||
<b v-text="detail.bankName"/>
|
||||
<el-form-item label="贷款银行" prop="bankId" :rules="{ message: '请选择 贷款银行' }">
|
||||
<b v-text="detail.bankName" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款产品" prop="productType" :rules="{message:'请选择 贷款产品'}">
|
||||
<b v-text="dict.getLabel('loanProduct',detail.productType)"/>
|
||||
<el-form-item label="贷款产品" prop="productType" :rules="{ message: '请选择 贷款产品' }">
|
||||
<b v-text="dict.getLabel('loanProduct', detail.productType)" />
|
||||
</el-form-item>
|
||||
<el-form-item label="贷款金额(万)" prop="loanAmount" :rules="{message:'请输入 预期贷款额'}">
|
||||
<ai-input v-model.number="detail.loanAmount" :edit="!1"/>
|
||||
<el-form-item label="贷款金额(万)" prop="loanAmount">
|
||||
<ai-input v-model.number="detail.loanAmount" :edit="!1" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系人" prop="contacts" :rules="{message:'请输入 联系人'}">
|
||||
<ai-input v-model="detail.contacts" :edit="!1"/>
|
||||
<el-form-item label="联系人" prop="contacts" :rules="{ message: '请输入 联系人' }">
|
||||
<ai-input v-model="detail.contacts" :edit="!1" />
|
||||
</el-form-item>
|
||||
<el-form-item label="联系电话" prop="phone" :rules="{message:'请输入 联系电话'}">
|
||||
<ai-input v-model="detail.phone" :edit="!1"/>
|
||||
<el-form-item label="联系电话" prop="phone" :rules="{ message: '请输入 联系电话' }">
|
||||
<ai-input v-model="detail.phone" :edit="!1" />
|
||||
</el-form-item>
|
||||
</div>
|
||||
</ai-card>
|
||||
<ai-card title="标的信息">
|
||||
<template #right v-if="isEdit">
|
||||
<ai-eartag-picker @select="v=>detail.detailList=v" :instance="instance"
|
||||
:action="`/api/sell/apply/getClaimEarNumberList?contractNo=${detail.contractNo}`">
|
||||
<ai-eartag-picker @select="v => detail.detailList = v.map(e=>({biochipEarNumber:e}))" :instance="instance"
|
||||
:action="`/api/sell/apply/getClaimEarNumberList?contractNo=${detail.contractNo}`">
|
||||
<el-button type="text">选择</el-button>
|
||||
</ai-eartag-picker>
|
||||
</template>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`投保标的共${detail.insureNumber||0}只,已理赔标的共 @v 只`" color="red" :value="selectedEartags"/>
|
||||
<ai-table :tableData="detail.detailList" :colConfigs="columns" :isShowPagination="!1" hideOptions/>
|
||||
<ai-highlight class="mar-b8 font-14" :content="`投保标的共${detail.insureNumber || 0}只,已理赔标的共 @v 只`" color="red"
|
||||
:value="selectedEartags" />
|
||||
<ai-table :tableData="detail.detailList" :colConfigs="columns" :isShowPagination="!1" hideOptions />
|
||||
</ai-card>
|
||||
<ai-card title="解押材料" v-if="isEdit">
|
||||
<div class="font-12 mar-b8">只能上传JPG/PNG文件,且不超过2M,一次最多5张</div>
|
||||
<el-form-item v-for="(img,i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" :instance="instance" value-is-url :limit="5"/>
|
||||
<el-form-item v-for="(img, i) in formImages" :key="i" v-bind="img">
|
||||
<ai-uploader v-model="detail[img.prop]" :instance="instance" value-is-url :limit="5" />
|
||||
</el-form-item>
|
||||
</ai-card>
|
||||
<ai-card title="出栏解押记录" v-else>
|
||||
<ai-table :tableData="detail.list" :colConfigs="records" :isShowPagination="!1" hideOptions/>
|
||||
<ai-table :tableData="detail.list" :colConfigs="records" :isShowPagination="!1" hideOptions />
|
||||
</ai-card>
|
||||
</el-form>
|
||||
<div slot="footer">
|
||||
|
||||
@@ -64,8 +64,8 @@ export default {
|
||||
<template #left>
|
||||
<ai-input placeholder="贷款合同号" v-model="search.contractNo"/>
|
||||
<ai-search label="贷款日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="养殖户" v-model="search.applyName"/>
|
||||
<ai-input placeholder="养殖场" v-model="search.farmName"/>
|
||||
|
||||
@@ -64,8 +64,8 @@ export default {
|
||||
<ai-input placeholder="贷款合同号" v-model="search.contractNo"/>
|
||||
<ai-select placeholder="全部审批状态" v-model="search.auditStatus" dict="auditStatus"/>
|
||||
<ai-search label="投保日期">
|
||||
<el-date-picker v-model="search.auditBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.auditEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.auditBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.auditEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-input placeholder="养殖户" v-model="search.applyName"/>
|
||||
</template>
|
||||
|
||||
@@ -95,6 +95,8 @@ export default {
|
||||
if (data?.access_token) {
|
||||
this.setToken([data.token_type, data.access_token].join(" "))
|
||||
this.handleGotoHome()
|
||||
} else {
|
||||
this.$message.error(data?.msg || "登录失败!")
|
||||
}
|
||||
},
|
||||
handleGotoHome() {
|
||||
|
||||
@@ -5,7 +5,7 @@ import AiEartagPicker from "../components/AiEartagPicker.vue";
|
||||
const columns = [
|
||||
{label: "序号", type: "index"},
|
||||
{label: "药品名称", prop: "drugName"},
|
||||
{label: "药量", prop: "dosage"},
|
||||
{label: "药量(ml)", prop: "dosage"},
|
||||
{label: "生产厂家", prop: "factory"},
|
||||
{label: "厂家批号", prop: "batchNumber"},
|
||||
{label: "疾病名称", prop: "diseaseName"},
|
||||
@@ -56,7 +56,7 @@ export default {
|
||||
return id && this.instance.post("/api/breed/treatment/getInfo", null, {params: {biochipEarNumber: id}}).then(res => {
|
||||
if (res?.data) {
|
||||
const detail = res.data
|
||||
detail.detailList = detail.immunityList || []
|
||||
detail.detailList = detail.treatmentList || []
|
||||
return this.detail = {...detail}
|
||||
}
|
||||
})
|
||||
@@ -95,7 +95,7 @@ export default {
|
||||
},
|
||||
created() {
|
||||
this.dict.load("yesOrNo")
|
||||
this.detail.treatmentTime = new Date()
|
||||
this.detail.treatmentTime = this.$moment().format("YYYY-MM-DD HH:mm:ss")
|
||||
this.getDetail()
|
||||
}
|
||||
}
|
||||
@@ -138,7 +138,7 @@ export default {
|
||||
<template v-if="isAdd">
|
||||
<div class="grid c-3">
|
||||
<el-form-item label="治疗日期" prop="treatmentTime" :rules="{required:true,message:'请选择 治疗日期'}">
|
||||
<el-date-picker v-model="detail.treatmentTime"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="detail.treatmentTime"/>
|
||||
</el-form-item>
|
||||
<el-form-item v-for="(item,i) in formItems" :key="i" v-bind="item">
|
||||
<ai-input v-model="detail[item.prop]"/>
|
||||
@@ -162,9 +162,9 @@ export default {
|
||||
<ai-dialog v-model="dialog" title="治疗登记" @closed="form={}" @confirm="submit">
|
||||
<el-form size="small" label-width="120px" class="grid">
|
||||
<el-form-item label="治疗日期" prop="treatmentTime" :rules="{required:true,message:'请选择 治疗日期'}">
|
||||
<el-date-picker v-model="form.treatmentTime"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="form.treatmentTime"/>
|
||||
</el-form-item>
|
||||
<el-form-item v-for="item in formItems" v-bind="item">
|
||||
<el-form-item v-for="(item,i) in formItems" :key="i" v-bind="item">
|
||||
<ai-input v-model="detail[item.prop]"/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
|
||||
@@ -64,12 +64,12 @@ export default {
|
||||
<ai-select placeholder="全部养殖舍" v-model="search.houseId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.farmId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-select placeholder="全部养殖栏" v-model="search.penId" :instance="instance" :action="`/api/siteUser/querySiteById?id=${search.houseId||-1}`" :prop="{label:'name'}"/>
|
||||
<ai-search label="治疗日期">
|
||||
<el-date-picker v-model="search.treatmentBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.treatmentEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.treatmentBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.treatmentEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<ai-search label="登记日期">
|
||||
<el-date-picker v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.beginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.endDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
<el-input placeholder="原场耳标号" v-model="search.originalEarNumber" size="small" clearable/>
|
||||
<el-input placeholder="生物芯片耳标号" v-model="search.biochipEarNumber" size="small" clearable/>
|
||||
|
||||
@@ -16,9 +16,9 @@ export default {
|
||||
return hash == "#add" ? add : list
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {}
|
||||
}
|
||||
created() {
|
||||
this.dict.load( "yesOrNo", "category", "variety", "dataSources")
|
||||
},
|
||||
}
|
||||
</script>
|
||||
|
||||
|
||||
@@ -72,7 +72,6 @@ export default {
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.dict.load("yesOrNo", "category", "variety", "dataSources")
|
||||
this.getDetail()
|
||||
}
|
||||
}
|
||||
@@ -102,7 +101,7 @@ export default {
|
||||
<b v-text="detail.variety"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="最近称重时间">
|
||||
<b v-text="detail.lastCreateTime"/>
|
||||
<b v-text="detail.todayCreateTime||detail.lastCreateTime"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="最新体重(公斤)">
|
||||
<b v-text="detail.todayWeight||detail.lastWeight"/>
|
||||
@@ -128,7 +127,7 @@ export default {
|
||||
<el-date-picker v-model="form.createTime" :readonly="form.id" value-format="yyyy-MM-dd HH:mm:ss"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="体重(公斤)" prop="weight" :rules="[{required:true,message:'请输入体重(公斤)'}]">
|
||||
<ai-input v-model.number="form.weight"/>
|
||||
<ai-input type="number" v-model="form.weight"/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</ai-dialog>
|
||||
|
||||
@@ -71,8 +71,8 @@ export default {
|
||||
<ai-select placeholder="全部品种" v-model="search.variety" dict="variety"/>
|
||||
<el-input placeholder="生物芯片耳标号" v-model="search.biochipEarNumber" dict="authStatus" size="small" clearable/>
|
||||
<ai-search label="称重日期">
|
||||
<el-date-picker v-model="search.weightBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker v-model="search.weightEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.weightBeginDate" type="datetime" placeholder="开始日期" size="small"/>
|
||||
<el-date-picker value-format="yyyy-MM-dd HH:mm:ss" v-model="search.weightEndDate" type="datetime" placeholder="结束日期" size="small"/>
|
||||
</ai-search>
|
||||
</template>
|
||||
</ai-search-bar>
|
||||
|
||||
19
project/xumu/components/AiAudit.vue
Normal file
19
project/xumu/components/AiAudit.vue
Normal file
@@ -0,0 +1,19 @@
|
||||
<script>
|
||||
const options = [
|
||||
{ dictValue: 2, dictName: '同意' },
|
||||
{ dictValue: 3, dictName: '不同意' }
|
||||
]
|
||||
export default {
|
||||
name: "AiAudit",
|
||||
data() {
|
||||
return {
|
||||
options, auditStatus: ""
|
||||
}
|
||||
},
|
||||
}
|
||||
</script>
|
||||
<template>
|
||||
<section class="AiAudit">
|
||||
<ai-select v-model="auditStatus" :select-list="options" v-bind="$attrs" v-on="$listeners" />
|
||||
</section>
|
||||
</template>
|
||||
@@ -3,9 +3,10 @@ export default {
|
||||
name: "AiEartagPicker",
|
||||
props: {
|
||||
instance: Function,
|
||||
value: {default: () => []},
|
||||
action: {default: "/api/breed/earTag/getEarTagByPenId"},
|
||||
penId: String
|
||||
value: { default: () => [] },
|
||||
action: { default: "/api/breed/earTag/getEarTagByPenId" },
|
||||
penId: String,
|
||||
valueKey: { type: String, default: "biochipEarNumber" }
|
||||
},
|
||||
model: {
|
||||
prop: "value",
|
||||
@@ -15,7 +16,8 @@ export default {
|
||||
return {
|
||||
list: [],
|
||||
dialog: false,
|
||||
selected: []
|
||||
selected: [],
|
||||
origin: []
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
@@ -39,14 +41,22 @@ export default {
|
||||
getEartag() {
|
||||
!/undefined/.test(this.api) && this.instance.post(this.api).then(res => {
|
||||
if (res?.data) {
|
||||
this.list = res.data
|
||||
const key = this.valueKey
|
||||
this.origin = res.data ?? []
|
||||
this.list = res.data?.map(v => {
|
||||
if (typeof v == 'string') {
|
||||
return { key: v, label: v }
|
||||
} else if (key) {
|
||||
return { key: v[key], label: v[key] }
|
||||
}
|
||||
}) || []
|
||||
}
|
||||
})
|
||||
},
|
||||
handleConfirm() {
|
||||
this.dialog = false
|
||||
this.$emit("input", this.selected)
|
||||
this.$emit("select", this.list.filter(v => this.selected.includes(v.id)))
|
||||
this.$emit("select", this.origin.filter(v => this.selected.includes(v?.[this.valueKey] ?? v)))
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -54,15 +64,16 @@ export default {
|
||||
|
||||
<template>
|
||||
<section class="AiEartagPicker">
|
||||
<div style="width: auto;" v-if="$slots.default" @click="dialog=true">
|
||||
<slot/>
|
||||
<div style="width: auto;" v-if="$slots.default" @click="dialog = true">
|
||||
<slot />
|
||||
</div>
|
||||
<el-select v-else :value="value" clearable multiple placeholder="请选择">
|
||||
<el-option v-for="op in list" :key="op.id" :label="op.earTag" :value="op.id"/>
|
||||
<div slot="prefix" @click.stop="dialog=true"/>
|
||||
<el-option v-for="(op, i) in list" :key="i" :label="op.label" :value="op.key" />
|
||||
<div slot="prefix" @click.stop="dialog = true" />
|
||||
</el-select>
|
||||
<ai-dialog v-model="dialog" title="选择牲畜" width="640px" @confirm="handleConfirm" @closed="selected=[]" @open="selected=value">
|
||||
<el-transfer :data="list" v-model="selected" :titles="['可选','已选择']"/>
|
||||
<ai-dialog v-model="dialog" title="选择牲畜" width="800px" @confirm="handleConfirm" @closed="selected = []"
|
||||
@open="selected = value">
|
||||
<el-transfer :data="list" v-model="selected" :titles="['可选', '已选择']" />
|
||||
</ai-dialog>
|
||||
</section>
|
||||
</template>
|
||||
@@ -84,10 +95,21 @@ export default {
|
||||
right: 0;
|
||||
z-index: 999;
|
||||
|
||||
& > div {
|
||||
&>div {
|
||||
height: 100%;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
:deep(.el-transfer) {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
|
||||
.el-transfer-panel {
|
||||
width: auto;
|
||||
min-width: 200px;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
|
||||
40
project/xumu/components/AiEartagRemote.vue
Normal file
40
project/xumu/components/AiEartagRemote.vue
Normal file
@@ -0,0 +1,40 @@
|
||||
<script>
|
||||
|
||||
export default {
|
||||
name: "AiEartagRemote",
|
||||
props: {
|
||||
instance: Function
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
value: "",
|
||||
info: {}
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
getText(biochipEarNumber) {
|
||||
this.info = {}
|
||||
return this.instance.post("/api/breed/earTag/page", {biochipEarNumber, pageSize: 10, pageNum: 1}).then(res => {
|
||||
if (res?.data?.records) {
|
||||
this.info = res.data.records[0]
|
||||
this.$emit('enter', this.info)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<section class="AiEartagRemote">
|
||||
<ai-input v-model="value" placeholder="请输入耳标号按回车查询,或扫描耳标号" @keyup.enter.native="getText(value)"/>
|
||||
</section>
|
||||
|
||||
</template>
|
||||
|
||||
<style scoped lang="scss">
|
||||
.AiEartagRemote {
|
||||
gap: 8px;
|
||||
width: 100%;
|
||||
}
|
||||
</style>
|
||||
48
project/xumu/components/AiIdcardRemote.vue
Normal file
48
project/xumu/components/AiIdcardRemote.vue
Normal file
@@ -0,0 +1,48 @@
|
||||
<script>
|
||||
|
||||
export default {
|
||||
name: "AiIdcardRemote",
|
||||
props: {
|
||||
instance: Function
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
value: "",
|
||||
info: {}
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
infoText: v => [v.info.name, v.info.idCard].filter(Boolean)?.join(' ')?.trim()
|
||||
},
|
||||
methods: {
|
||||
getText(idCard) {
|
||||
this.info = {}
|
||||
if (!this.ID.check(idCard)) return this.$message.error("请输入正确的身份证号")
|
||||
return this.instance.post("/api/user/getUserByIdCard", null, {params: {idCard}}).then(res => {
|
||||
if (res?.data) {
|
||||
this.info = res.data
|
||||
this.$emit('enter', this.info.id)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<section class="AiIdcardRemote flex">
|
||||
<ai-input v-model="value" @keyup.enter.native="getText(value)"/>
|
||||
<b class="text" v-text="infoText"/>
|
||||
</section>
|
||||
|
||||
</template>
|
||||
|
||||
<style scoped lang="scss">
|
||||
.AiIdcardRemote {
|
||||
gap: 8px;
|
||||
|
||||
.AiInput {
|
||||
min-width: 300px;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
@@ -8,24 +8,17 @@ import extra from "../config.json"
|
||||
Vue.use(Vuex)
|
||||
|
||||
export default new Vuex.Store({
|
||||
state: {
|
||||
},
|
||||
state: {},
|
||||
mutations: {
|
||||
signOut(state, flag) {
|
||||
const base = extra.base || ""
|
||||
if (flag) {
|
||||
state.user.token = null;
|
||||
state.user.info = {}
|
||||
new Promise(resolve => {
|
||||
flag ? resolve() : axios.delete('/auth/token/logout').then(resolve)
|
||||
}).then(() => {
|
||||
localStorage.removeItem("vuex");
|
||||
sessionStorage.clear();
|
||||
location.href = base + '/login' + location.hash;
|
||||
} else {
|
||||
axios.delete('/auth/token/logout').then(() => {
|
||||
state.user.token = null;
|
||||
sessionStorage.clear();
|
||||
state.user.info = {}
|
||||
location.href = base + '/login';
|
||||
});
|
||||
}
|
||||
location.href = [base, '/login', location.hash].join('');
|
||||
})
|
||||
},
|
||||
},
|
||||
getters: {
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
@import "ckeditor";
|
||||
@import "vars";
|
||||
|
||||
$cdn: "https://cdn.cunwuyun.cn/";
|
||||
$cdn: "https://cdn.sinoecare.com/";
|
||||
$--color-primary: $primaryColor;
|
||||
$--color-text-placeholder: $placeholderColor;
|
||||
$--border-color-base: $borderColor;
|
||||
@@ -164,7 +164,7 @@ $--font-path: '~element-ui/lib/theme-chalk/fonts';
|
||||
缺省页相关样式
|
||||
*/
|
||||
.no-data {
|
||||
background: url("https://cdn.cunwuyun.cn/ui/svg/NoData.svg") no-repeat center;
|
||||
background: url("https://cdn.sinoecare.com/ui/svg/NoData.svg") no-repeat center;
|
||||
background-size: 120px 120px;
|
||||
height: 120px;
|
||||
margin: 48px auto 10px;
|
||||
@@ -174,28 +174,28 @@ $--font-path: '~element-ui/lib/theme-chalk/fonts';
|
||||
缺省页相关样式
|
||||
*/
|
||||
.ai-empty__bg {
|
||||
background: url("https://cdn.cunwuyun.cn/ui/svg/empty.svg") no-repeat center;
|
||||
background: url("https://cdn.sinoecare.com/ui/svg/empty.svg") no-repeat center;
|
||||
background-size: 120px 120px;
|
||||
height: 120px;
|
||||
margin: 48px auto 0;
|
||||
}
|
||||
|
||||
.no-permission {
|
||||
background: url("https://cdn.cunwuyun.cn/ui/svg/NoAuthority.svg") no-repeat center;
|
||||
background: url("https://cdn.sinoecare.com/ui/svg/NoAuthority.svg") no-repeat center;
|
||||
background-size: 120px 120px;
|
||||
height: 120px;
|
||||
margin-top: 48px;
|
||||
}
|
||||
|
||||
.no-message {
|
||||
background: url("https://cdn.cunwuyun.cn/ui/svg/NoMessage.svg") no-repeat center;
|
||||
background: url("https://cdn.sinoecare.com/ui/svg/NoMessage.svg") no-repeat center;
|
||||
background-size: 120px 120px;
|
||||
height: 120px;
|
||||
margin-top: 48px;
|
||||
}
|
||||
|
||||
.done-success {
|
||||
background: url("https://cdn.cunwuyun.cn/ui/svg/Success.svg") no-repeat center;
|
||||
background: url("https://cdn.sinoecare.com/ui/svg/Success.svg") no-repeat center;
|
||||
background-size: 120px 120px;
|
||||
height: 120px;
|
||||
}
|
||||
@@ -207,7 +207,7 @@ $--font-path: '~element-ui/lib/theme-chalk/fonts';
|
||||
}
|
||||
|
||||
.developing {
|
||||
background: url("https://cdn.cunwuyun.cn/ui/svg/developing.svg") no-repeat center;
|
||||
background: url("https://cdn.sinoecare.com/ui/svg/developing.svg") no-repeat center;
|
||||
background-size: 400px 320px;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
@@ -657,11 +657,11 @@ h1, h2, h3, p {
|
||||
*/
|
||||
|
||||
.signLeftBg {
|
||||
background-image: url('#{$cdn}/ui/background/#{$theme}/loginLeft.png');
|
||||
background-image: url('#{$cdn}ui/background/#{$theme}/loginLeft.png');
|
||||
}
|
||||
|
||||
.navBg {
|
||||
background-image: url('#{$cdn}/ui/background/#{$theme}/nav_bg.png');
|
||||
background-image: url('#{$cdn}ui/background/#{$theme}/nav_bg.png');
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -26,8 +26,8 @@
|
||||
<template slot-scope="{row,$index}">
|
||||
<span v-if="colConfig.dict" :style="{color:colConfig.color||dict.getColor(colConfig.dict, row[colConfig.prop])}" v-text="dict.getLabel(colConfig.dict, row[colConfig.prop])"/>
|
||||
<render-slot v-else-if="colConfig.render" :render="colConfig.render" :row="row" :index="$index" :column="colConfig"/>
|
||||
<el-input v-else-if="colConfig.edit" v-model="row[colConfig.prop]" size="small" placeholder="请输入" clearable/>
|
||||
<el-input v-else-if="colConfig.num" v-model.number="row[colConfig.prop]" size="small" placeholder="请输入" clearable/>
|
||||
<ai-input v-else-if="colConfig.edit" v-model="row[colConfig.prop]"/>
|
||||
<ai-input v-else-if="colConfig.num" type="number" v-model="row[colConfig.prop]"/>
|
||||
<ai-select v-else-if="colConfig.select" v-model="row[colConfig.prop]" v-bind="colConfig.select"/>
|
||||
<ai-uploader v-else-if="colConfig.upload" v-model="row[colConfig.prop]" :limit="1" v-bind="colConfig.upload"/>
|
||||
<ai-open-data v-else-if="colConfig.openType" :type="colConfig.openType" :openid="row[colConfig.prop]"/>
|
||||
|
||||
Reference in New Issue
Block a user