56 Commits

Author SHA1 Message Date
aixianling
8b72cc93a0 refactor(xumu): 优化保险审计提交逻辑
- 添加耳号列表处理,提高数据准确性
- 使用对象展开运算符简化代码结构
- 优化 API 请求数据格式
2025-01-22 09:41:03 +08:00
aixianling
6819b17126 feat(AppSellApply): 优化 add 组件并添加耳标号列表
- 重新格式化代码,使其更加规范和可读
- 在提交时添加 earNumberList 字段,包含选中的生物芯片耳标号
- 优化 AiEartagPicker 组件的使用方式
- 调整表格和表单的样式
2025-01-22 09:39:33 +08:00
aixianling
d9a35f0081 fix(AppLoanApply): 修复添加页面格式问题
- 调整了代码缩进和格式,使其更加规范
- 修复了一些小的语法问题,如模板字符串中的引号
- 优化了部分变量命名,使其更具可读性
2025-01-21 14:03:45 +08:00
aixianling
4b26e6f5d0 components(xumu): 在 AppDeathAudit 和 AppOutAudit 组件中添加 AiAudit 组件引用
- 在 AppDeathAudit/add.vue 中引入并注册 AiAudit 组件
- 在 AppOutAudit/add.vue 中引入并注册 AiAudit 组件
2025-01-21 10:36:10 +08:00
aixianling
ebb28ed676 refactor(xumu): 优化代码格式和组件使用
- 格式化代码,调整缩进和空格
- 使用 dict.getLabel 方法获取类别和品种标签
- 在审批状态下使用 ai-audit 组件替代 ai-select 组件
2025-01-21 10:25:41 +08:00
aixianling
a059d2bd57 fix(xumu): 修复审计页面数据获取问题
- 在 AppDeathAudit 和 AppOutAudit 组件中,修改了 getDetail 方法
- 从 API 响应中获取正确的数据结构,确保详细信息正确显示
- 优化了代码格式,提高了可读性
2025-01-21 10:09:13 +08:00
aixianling
fde372007f refactor(xumu): 优化 API 请求参数传递方式
- 在 AppDeathAudit 和 AppOutAudit 组件中,修改了 getDetail 方法的 API 请求参数传递方式
- 从使用 params 参数改为直接传递对象,简化了请求参数的处理
2025-01-21 09:50:15 +08:00
aixianling
9aed740388 fix(AppDeathAudit): 修改导出接口地址
- 将导出接口地址从 "/api/breed/death/export" 修改为 "/api/breed/death/exportAudit"
- 该修改确保了正确的数据被导出,解决了错误导出的问题
2025-01-21 09:21:51 +08:00
aixianling
8a20db021a refactor(xumu): 优化获取详情数据接口及处理逻辑
- 修改请求接口地址:将 "/api/breed/death/page" 更改为 "/api/breed/death/getAuditPage"
- 优化数据处理逻辑:直接使用 res.data 代替 res.data.records[0]
2025-01-21 09:21:06 +08:00
aixianling
8daf15cf3f refactor(xumu): 修改 AppOutAudit 详情获取接口
- 将 getAuditInfo 接口更改为 getAuditPage 接口
- 更新接口 URL 以适应后端接口变更
2025-01-21 09:20:06 +08:00
aixianling
ba8dc41c83 refactor(ui): 更新 CDN 域名并统一资源路径格式
- 将 CDN 域名从 https://cdn.cunwuyun.cn/ 更改为 https://cdn.sinoecare.com/
- 统一资源路径格式,移除多余的斜杠
- 更新了多个样式类中的背景图片 URL
2025-01-21 09:15:50 +08:00
aixianling
6744b18240 feat(xumu): 新增保险产品类型字典
- 在 AppClaimApply 和 AppClaimAudit 组件中添加 productType 字典加载
- 在 add.vue 组件中使用 productType 字典获取保险产品类型标签
2025-01-17 11:09:53 +08:00
aixianling
a3ea6d9c51 fix(xumu): 修复理赔申请页面的耳标选择和数据加载问题
- 优化耳标选择功能,将选中的耳标数据格式化后赋值给 detail.detailList
- 初始化 detail 对象时添加 list 属性,确保数据结构一致性
- 优化数据加载逻辑,处理可能的空值情况
- 调整页面布局和样式,提高可读性
2025-01-17 11:07:20 +08:00
aixianling
5fa30a0e0e refactor(xumu): 优化 AppLoanApply 添加页面代码
- 在 submit 方法中添加 earNumberList 数组,用于存储生物芯片耳号
- 优化代码结构,提高可读性和可维护性
2025-01-17 10:46:51 +08:00
aixianling
6b030791bb feat(AppInsuranceAudit): 优化耳标号选择和养殖场查询功能
- 在 add.vue 中增加 targetUser 字段,用于查询养殖场
- 修改 AiEartagPicker 组件,增加 valueKey 属性默认值
- 优化代码格式和样式
2025-01-17 10:36:41 +08:00
aixianling
d0922c5309 feat(AppLoanAudit): 优化审核页面功能和样式
- 新增 AiAudit 组件用于审批状态选择
- 调整审批状态字段的验证规则
- 优化页面布局和样式,统一代码格式
- 引入新的组件和 API 接口
2025-01-17 10:17:55 +08:00
aixianling
d46bb82086 refactor(xumu): 解除 AppInsuranceAudit 页面的代码注释
- 移除了 handleAudit 方法中对 API 提交逻辑的注释
- 恢复了代码的原始功能,允许用户提交保险审核申请
2025-01-17 10:11:21 +08:00
aixianling
1ead1b2e9a refactor(xumu): 优化保险申请和审核功能
- 修改保险产品显示逻辑,使用字典标签展示
- 临时注释审计提交功能
- 优化审计状态选择器配置
- 条件渲染保单订单号输入框
2025-01-17 10:10:54 +08:00
aixianling
c5f4f9b356 feat(AppInsuranceAudit): 新增产品类型字典支持
- 在 AppInsuranceAudit 组件中加载 productType 字典
- 在 add 组件中使用 productType 字典显示投保产品名称
- 优化 add 组件中的表单布局
2025-01-17 09:51:05 +08:00
aixianling
3fbde7f193 feat(AppInsuranceAudit): 添加审批组件并优化投保页面
- 新增 AiAudit 组件用于审批操作
- 在投保页面引入并使用 AiAudit 组件
- 优化投保页面布局和样式
2025-01-17 09:25:50 +08:00
aixianling
e5abd1514b feat(AppInsuranceAudit): 添加保险资料审批功能
- 在保险资料卡片中增加审批选项
- 添加审批状态选择框,包括"同意"和"不同意"两个选项
- 审批选项为必选项,增加了验证规则
2025-01-17 09:13:17 +08:00
aixianling
33ed4fe5d5 style(xumu): 格式化 AppInsuranceAudit/add.vue 文件
- 使用 ESLint 规则格式化了代码
- 调整了缩进、空格和换行
- 修复了一些小的语法问题
2025-01-17 09:10:23 +08:00
aixianling
4051b31101 refactor(xumu): 优化理赔申请列表展示逻辑
- 根据 remarks 字段判断是否可申请理赔,而非拼接 status 和 auditStatus
- 简化 permit 字段的使用,直接用于判断是否显示理赔按钮
2025-01-16 10:49:13 +08:00
aixianling
94b1788e8c refactor(xumu): 更新保险申请审核状态字典
- 将审核状态字典从 'auditStatus' 修改为 'insuranceAuditStatus'- 在 add.vue、AppInsuranceApply.vue 和 list.vue 文件中进行了相应更新
2025-01-16 09:58:18 +08:00
aixianling
7944a1a8e3 refactor(xumu): 优化保险申请和审核功能
- 修改身份证和营业执照等文件的上传规则,要求在添加或编辑时必须上传
- 在保险申请提交时添加耳号列表参数
- 修改保险审核列表的审批按钮显示逻辑,仅当状态为"01"时显示
2025-01-16 09:36:38 +08:00
aixianling
17b28025d8 fix(AiEartagPicker): 修复确认选择后原始数据丢失的问题
- 添加 origin 数组以保存初始获取的数据
- 修改 handleConfirm 方法,确保选中的数据来自原始数据
2025-01-15 15:59:58 +08:00
aixianling
0a6b77943f feat(xumu): 优化耳标号选择功能
- 在 AppInsuranceApply 和 AppLoanApply 组件中添加 value-key 属性
- 在 AiEartagPicker 组件中增加对 valueKey 属性的支持- 优化 AiEartagPicker 组件的样式和布局
2025-01-15 15:51:09 +08:00
aixianling
a599566b20 refactor(535): 调整耳标照片上传逻辑
- 将 earPhoto 属性改为 picture
- 添加 upload 配置项,限制上传数量为 1- 优化 columns 数据结构,移除冗余定义
2025-01-14 11:58:59 +08:00
aixianling
1a7031342f refactor(536): 优化 AiTable 组件的输入框使用
- 将 el-input 替换为 ai-input 组件,统一输入框样式
- 为数字类型输入框添加 type="number" 属性,提高输入准确性
2025-01-14 11:55:14 +08:00
aixianling
516a8edb5e refactor(537): 优化体重输入框类型
- 将体重输入框的类型从默认改为 number,确保只能输入数字
-移除 v-model.number 修饰符,因 type="number" 已
2025-01-14 11:52:50 +08:00
aixianling
f4e2100882 fix(542): 修复添加页面接口参数和布局
- 在 AppDeathManage 和 AppOutManage 的 add.vue 文件中,为 ai-eartag-remote 组件添加 class="row",优化布局
- 在 AppOutManage 的 add.vue 文件中,修正出栏接口参数 outTime 之前错误使用 deathTime
- 在 AiEartagRemote 组件中,简化 API 请求参数结构
2025-01-14 11:50:45 +08:00
aixianling
9f6998e042 refactor(BUG 541): 优化治疗时间初始化
- 在 AppImmunityManage 和 AppTreatmentManage 组件中,移除了治疗时间的自动初始化
- 在 AppTreatmentManage 组件中,将治疗时间初始化为当前时间的字符串格式
2025-01-14 11:37:19 +08:00
aixianling
f730850d93 feat(BUG 540): 新增免疫登记功能
- 添加免疫登记对话框和相关表单
- 实现免疫信息的添加和更新功能
- 优化表单样式,调整标签宽度和对齐方式
2025-01-14 11:28:46 +08:00
aixianling
0ef83a945f refactor(BUG 538): 调整字典数据加载时机
- 移除 add.vue 中的 created 钩子中的字典加载逻辑
- 在 AppWeightManage.vue 中添加 created 钩子,统一处理字典加载
2025-01-14 11:26:01 +08:00
aixianling
cbfd68f50c refactor(BUG 539): 为药物和疫苗的剂量添加单位 ml- 在 AppBreedArchive、AppImmunityManage 和 AppTreatmentManage组件中
- 将"药量"列的标题修改为"药量(ml)"
- 此修改提高了数据的准确性和可读性
2025-01-14 11:10:02 +08:00
aixianling
7762eb6d24 fix(xumu): 修复死亡管理和出栏管理中的图片无法回显的问题
- 在 AppDeathManage 和 AppOutManage 组件中,将图片数据转换为 JSON 字符串后提交
- 修复了后端接口对图片数据的接收问题
2025-01-09 16:43:02 +08:00
aixianling
db1a323921 refactor(xumu): 移除表单照片的验证规则
移除了 AppDeathManage 和 AppOutManage 组件中照片上传的验证规则。这个改动统一了照片上传的规则,提高了代码的一致性和可维护性。

受影响的主要文件:
- project/xumu/AppDeathManage/add.vue
- project/xumu/AppOutManage/add.vue

具体改动:
- 删除了 formImages 数组中每个对象的 rules 属性
- 优化了部分代码格式,如空格和换行
2025-01-09 16:39:23 +08:00
aixianling
1a61475f57 fix(xumu): 修复耳标号查询接口的参数传递方式- 将参数从第三个参数移到第二个参数位置,以符合 Axios库的正确用法
-这个修改可以解决耳标号查询功能不工作的问题
2025-01-09 16:36:36 +08:00
aixianling
356e6438e0 fix(xumu): 修复保险申请和治疗管理页面的数据加载问题- 在 AppInsuranceApply 组件中,将 detailList 的默认值改为 detailList || [],以确保数据正确加载
- 在 AppTreatmentManage 组件中,将 detailList 的
2025-01-09 15:48:02 +08:00
aixianling
5fe82a68ef fix(xumu): 修复耳标号查询功能
- 更新 API 请求参数,添加 pageSize 和 pageNum
- 修改数据处理逻辑,使用 records[0] 而不是直接使用 data
- 优化代码格式,删除多余的空格和换行
2025-01-09 15:41:39 +08:00
aixianling
9b6e02810a fix(xumu): 修复死亡管理和淘汰管理页面的查看模式显示逻辑
- 在 AppDeathManage 和 AppOutManage 组件中,为死亡日期、死亡原因、淘汰日期和淘汰原因字段添加 v-else指令
- 这样在查看模式下只显示文本,而不显示输入框
2025-01-09 15:11:27 +08:00
aixianling
f0a32ad868 feat(xumu): 添加远程耳标号查询功能
- 在 AppDeathManage 和 AppOutManage 组件中集成 AiEartagRemote 组件
- 实现耳标号远程查询和自动填充功能
-优化用户输入体验,提高数据准确性
2025-01-09 15:09:28 +08:00
aixianling
ce64bfd54d style(xumu): 优化 AppTreatmentManage 组件中的表单项
- 为 formItems 循环渲染的表单项添加 key 属性,以提高渲染性能和稳定性
2025-01-09 14:51:58 +08:00
aixianling
a53d25fae2 refactor(xumu): 为 el-date-picker 组件添加 value-format 属性
- 在多个组件中,为 el-date-picker 组件添加 value-format="yyyy-MM-dd HH:mm:ss" 属性
- 这样做可以确保日期时间的格式一致性,避免潜在的时间格式问题
2025-01-09 14:39:56 +08:00
aixianling
08d5e0e4fd fix(AiEartagPicker): 修复耳标选择器组件
- 优化代码格式和缩进
- 修复 penId 属性未使用的问题
- 改进 getEartag 方法,确保正确处理返回数据
- 更新模板中的点击事件和样式
2025-01-09 11:55:59 +08:00
aixianling
b23f8325f4 refactor(xumu): 优化字典数据加载和组件结构
- 移动字典数据加载到父组件 AppDeathManage
- 修复死亡日期和死亡原因的验证规则
- 优化死亡原因的显示逻辑
- 移除子组件中的重复字典数据加载
2025-01-09 11:43:16 +08:00
aixianling
0adb2b1486 feat(AppWeightManage): 更新体重信息显示逻辑
- 在"最近称重时间"字段中,优先显示 todayCreateTime,若为空则显示 lastCreateTime
- 在"最新体重(公斤)"字段中,优先显示 todayWeight,若为空则显示 lastWeight
2025-01-09 11:37:26 +08:00
aixianling
38082397a9 style(xumu): 将只读属性改为禁用
- 在 AppInsuranceAudit 和 AppLoanAudit 组件
2025-01-09 10:40:12 +08:00
aixianling
4d527dc8ec feat(BUG 534 533): 添加身份证远程查询功能
- 在 AppInsuranceAudit 和 AppLoanAudit 组件中集成 AiIdcardRemote 组件
- 实现身份证信息查询和自动填充功能
- 优化用户信息获取逻辑,提高用户体验
2025-01-09 10:38:41 +08:00
aixianling
d90aca62e4 feat(AppAccountManage): 添加身份证号输入框
- 在表单中新增身份证号字段,设置为必填项
- 使用 ai-input组件替代 el-input 组件,以适应特殊输入需求
2025-01-09 09:16:12 +08:00
aixianling
44f11be05c fix(BUG 517): 修改账号管理对话框标题
- 将编辑状态下的对话框标题从"功能分配"改为"编辑账号"
- 优化用户体验,使对话框标题与操作内容更加匹配
2025-01-08 16:27:59 +08:00
aixianling
7a21ab3804 feat(AppAccountConfigManage):BUG 519 修改对话框标题
- 将对话框标题从"认证材料"修改为"场地配置"
- 此修改提高了界面文案的准确性,更好地反映了对话框内容的主题
2025-01-08 16:24:22 +08:00
aixianling
6bb4802f15 refactor(store):BUG 524 530 重构 signOut 逻辑
- 移除了 state 中的冗余代码
-优化了 signOut mutation 的逻辑结构
- 使用 Promise 处理异步操作,提高了代码可读性
- 简化了登录页面 URL 的拼接方式
2025-01-08 16:22:44 +08:00
aixianling
cfc8f3c8e0 feat(AppSign):BUG 525 添加登录失败错误提示
- 在登录接口返回数据中增加错误信息展示
- 使用 $message.error 方法显示错误提示
2025-01-08 16:01:46 +08:00
aixianling
3f26b8b6df refactor(AppRoleRightsManager): BUG 526 优化角色用户展示和编辑功能- 重新设计角色用户列表的展示方式,使用标签替代原有格式
- 调整角色名称列宽,提高可读性- 编辑角色时增加角色类型参数,可能为后续流程使用
2025-01-08 16:00:05 +08:00
aixianling
350ca644cf refactor(AppAccountManage):BUG 527 将“账户”改为“账号”
- 修改了 AppAccountManage 组件中的一个字段标签
- 将“账户”改为“账号”,以更准确地描述用户登录凭证
2025-01-08 15:43:20 +08:00
51 changed files with 672 additions and 493 deletions

View File

@@ -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>

View File

@@ -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 [

View File

@@ -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"},

View File

@@ -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>

View File

@@ -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>

View File

@@ -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">

View File

@@ -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>

View File

@@ -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>

View File

@@ -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"/>

View File

@@ -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"/>

View File

@@ -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>

View File

@@ -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"

View File

@@ -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>

View File

@@ -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"/>

View File

@@ -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"/>

View File

@@ -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 = {}) {

View File

@@ -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/>

View File

@@ -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"/>

View File

@@ -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/>

View File

@@ -17,7 +17,7 @@ export default {
}
},
created() {
this.dict.load("auditStatus", "insureType", "insureStatus", "category", "variety")
this.dict.load("insuranceAuditStatus", "insureType", "insureStatus", "category", "variety")
},
}
</script>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>

View File

@@ -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"/>

View File

@@ -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>

View File

@@ -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"/>

View File

@@ -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>

View File

@@ -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"/>

View File

@@ -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>

View File

@@ -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"/>

View File

@@ -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,
},
});
},

View File

@@ -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()

View File

@@ -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">

View File

@@ -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"/>

View File

@@ -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>

View File

@@ -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() {

View File

@@ -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>

View File

@@ -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/>

View File

@@ -16,9 +16,9 @@ export default {
return hash == "#add" ? add : list
}
},
data() {
return {}
}
created() {
this.dict.load( "yesOrNo", "category", "variety", "dataSources")
},
}
</script>

View File

@@ -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>

View File

@@ -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>

View 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>

View File

@@ -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>

View 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>

View 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>

View File

@@ -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: {

View File

@@ -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');
}
/**

View File

@@ -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]"/>