跟新数据
This commit is contained in:
@ -0,0 +1,182 @@
|
|||||||
|
<template>
|
||||||
|
<!-- 弹框 -->
|
||||||
|
<el-dialog v-model="dialogVisible" title="智能解析数据" width="80vw">
|
||||||
|
<div class="infoCnt">
|
||||||
|
<div class="baseInfo">
|
||||||
|
<div v-for="(item, index) in tableData" :key="index" >
|
||||||
|
发掘文本{{ index + 1 }}:<span class="text-danger">{{ item.fjWb }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<MyTable
|
||||||
|
:tableData="pageData.dtoList"
|
||||||
|
:tableColumn="pageData.tableColumn"
|
||||||
|
:tableHeight="pageData.tableHeight"
|
||||||
|
:key="pageData.keyCount"
|
||||||
|
:tableConfiger="pageData.tableConfiger"
|
||||||
|
:controlsWidth="pageData.controlsWidth"
|
||||||
|
:row-class-name="({ row }) => (row.status ? '' : 'row-deleted')"
|
||||||
|
>
|
||||||
|
<!-- 管辖单位 -->
|
||||||
|
<template #gxDwDm="{ row }">
|
||||||
|
<el-select
|
||||||
|
v-model="row.gxDwDm"
|
||||||
|
placeholder="请选择管辖单位"
|
||||||
|
style="width: 130px"
|
||||||
|
@change="handleDeptChange('gxDwMc', $event, row)"
|
||||||
|
:disabled="!row.status"
|
||||||
|
>
|
||||||
|
<el-option v-for="item in deptList" :key="item.value" :label="item.label" :value="item.value.toString()"/>
|
||||||
|
</el-select>
|
||||||
|
</template>
|
||||||
|
<!-- 是否关注 -->
|
||||||
|
<template #sfGz="{ row }">
|
||||||
|
<el-radio-group v-model="row.sfGz">
|
||||||
|
<el-radio v-for="(item, index) in D_BZ_SF" size="large" :key="index" :label="item.zdmc || item.label" :value="item.dm || item.value"></el-radio>
|
||||||
|
</el-radio-group>
|
||||||
|
</template>
|
||||||
|
<!-- 管辖单位 -->
|
||||||
|
<template #ryFjZp="{ row }"> 照片上传 </template>
|
||||||
|
<template :key="idx" v-for="(item,idx) in pageData.tableColumn.filter((col) => !['gxDwDm', 'sfGz', 'ryFjZp'].includes(col.prop) )" #[item.prop]="{ row }">
|
||||||
|
<el-input style="width: 100px" v-model="row[item.prop]" :placeholder="'请输入' + item.label" :disabled="!row.status" />
|
||||||
|
</template>
|
||||||
|
<!-- 操作列 -->
|
||||||
|
<template #controls="{ row, $index }">
|
||||||
|
<el-link v-if="row.status" type="danger" @click="delDictItem($index)">删除</el-link>
|
||||||
|
<el-link v-else type="primary" @click="recover($index)"> 恢复 </el-link>
|
||||||
|
</template>
|
||||||
|
</MyTable>
|
||||||
|
<div class="stats">
|
||||||
|
共 {{ pageData.dtoList.length }} 条数据, 其中
|
||||||
|
{{ pageData.dtoList.filter((x) => !x.status).length }} 条已标记删除
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<template #footer>
|
||||||
|
<div class="dialog-footer">
|
||||||
|
<el-button @click="dialogVisible = false">取消</el-button>
|
||||||
|
<el-button type="primary" @click="submitData"> 确定 </el-button>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-dialog>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import MyTable from "@/components/aboutTable/MyTable.vue";
|
||||||
|
import { qcckGet, qcckPost, qcckDelete } from "@/api/qcckApi.js";
|
||||||
|
import { reactive, ref, defineEmits,onMounted, getCurrentInstance, defineExpose } from "vue";
|
||||||
|
import { selectUserDeptPage } from "@/api/user-manage";
|
||||||
|
import { ElMessage } from "element-plus";
|
||||||
|
const { proxy } = getCurrentInstance();
|
||||||
|
const { D_BZ_SF } = proxy.$dict("D_BZ_SF"); //获取字典数据
|
||||||
|
const props = defineProps({
|
||||||
|
tableData: {
|
||||||
|
type: Array,
|
||||||
|
default: () => []
|
||||||
|
}
|
||||||
|
});
|
||||||
|
const emit = defineEmits(['upadate'])
|
||||||
|
const dialogVisible = ref(false);
|
||||||
|
const pageData = reactive({
|
||||||
|
dtoList: [],
|
||||||
|
keyCount: 0,
|
||||||
|
tableConfiger: {
|
||||||
|
rowHieght: 61,
|
||||||
|
showSelectType: "checkBox",
|
||||||
|
loading: false
|
||||||
|
},
|
||||||
|
tableHeight: 330,
|
||||||
|
total: 0,
|
||||||
|
pageConfiger: {
|
||||||
|
pageSize: 20,
|
||||||
|
pageCurrent: 1
|
||||||
|
},
|
||||||
|
controlsWidth: 80,
|
||||||
|
tableColumn: [
|
||||||
|
{ label: "管辖单位", prop: "gxDwDm", showSolt: true, width: 200 },
|
||||||
|
{ label: "姓名", prop: "ryXm", showSolt: true, width: 130 },
|
||||||
|
{ label: "手机号码", prop: "rySjhm", showSolt: true, width: 130 },
|
||||||
|
{ label: "身份证号码", prop: "rySfzh", showSolt: true, width: 130 },
|
||||||
|
{ label: "户籍地址", prop: "ryHjdz", showSolt: true, width: 130 },
|
||||||
|
{ label: "护照号码", prop: "ryHzhm", showSolt: true, width: 130 },
|
||||||
|
{ label: "现住地址", prop: "ryXzdz", showSolt: true, width: 130 },
|
||||||
|
{ label: "银行卡号", prop: "ryYhkh", showSolt: true, width: 130 },
|
||||||
|
{ label: "是否关注", prop: "sfGz", showSolt: true, width: 130 },
|
||||||
|
{ label: "附件照片", prop: "ryFjZp", showSolt: true, width: 130 }
|
||||||
|
]
|
||||||
|
});
|
||||||
|
const deptList = ref([]); //部门列表
|
||||||
|
onMounted(() => {
|
||||||
|
getdepartmentList();
|
||||||
|
});
|
||||||
|
// 获取部门列表
|
||||||
|
const getdepartmentList = () => {
|
||||||
|
selectUserDeptPage().then((res) => {
|
||||||
|
deptList.value = res?.records.map((item) => ({
|
||||||
|
label: item.deptName,
|
||||||
|
value: item.deptId
|
||||||
|
}));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
const handleDeptChange = (nameField, selectedValue, row) => {
|
||||||
|
// 找到选中的部门
|
||||||
|
const selectedDept = deptList.value.find((item) => item.value.toString() === selectedValue);
|
||||||
|
// 更新名称
|
||||||
|
row[nameField] = selectedDept ? selectedDept.label : "";
|
||||||
|
};
|
||||||
|
const init = () => {
|
||||||
|
dialogVisible.value = true;
|
||||||
|
qcckGet({}, "/mosty-gsxt/tbGsxtRqfjRy/createCbfj").then((res) => {
|
||||||
|
pageData.dtoList = res.map((item) => ({ ...item, status: true }));
|
||||||
|
}).catch(() => {
|
||||||
|
pageData.tableConfiger.loading = false;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
// 删除方法
|
||||||
|
const delDictItem = (index) => {
|
||||||
|
pageData.dtoList[index].status = false;
|
||||||
|
ElMessage.success("已标记为删除");
|
||||||
|
};
|
||||||
|
// 恢复方法
|
||||||
|
const recover = (index) => {
|
||||||
|
pageData.dtoList[index].status = true;
|
||||||
|
ElMessage.success("已恢复");
|
||||||
|
};
|
||||||
|
// 提交
|
||||||
|
const submitData = () => {
|
||||||
|
const validData = pageData.dtoList.filter((item) => item.status);
|
||||||
|
qcckPost(validData, "/mosty-gsxt/tbGsxtRqfjRy/saveList").then((res) => {
|
||||||
|
ElMessage.success("新增成功");
|
||||||
|
dialogVisible.value = false;
|
||||||
|
emit("upadate");
|
||||||
|
close();
|
||||||
|
})
|
||||||
|
};
|
||||||
|
|
||||||
|
defineExpose({ init });
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
/* 为已删除的行添加特殊样式 */
|
||||||
|
.el-table .row-deleted {
|
||||||
|
background-color: #fef0f0;
|
||||||
|
color: #f56c6c;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.infoCnt{
|
||||||
|
height: 63vh;
|
||||||
|
}
|
||||||
|
.baseInfo{
|
||||||
|
font-size: 16px;
|
||||||
|
max-height: 230px;
|
||||||
|
overflow: hidden;
|
||||||
|
overflow-y: auto;
|
||||||
|
line-height: 24px;
|
||||||
|
color: #000;
|
||||||
|
font-weight: 600;
|
||||||
|
letter-spacing: 1px;
|
||||||
|
.text-danger {
|
||||||
|
color: #333;
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
@ -3,9 +3,7 @@
|
|||||||
<el-dialog v-model="dialogVisible" title="智能解析数据" width="80vw">
|
<el-dialog v-model="dialogVisible" title="智能解析数据" width="80vw">
|
||||||
<div class="infoCnt">
|
<div class="infoCnt">
|
||||||
<div class="baseInfo">
|
<div class="baseInfo">
|
||||||
<div v-for="(item, index) in tableData" :key="index" >
|
发掘文本: <span style="font-weight: 400;">{{ props.contentText }}</span>
|
||||||
发掘文本{{ index + 1 }}:<span class="text-danger">{{ item.fjWb }}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<MyTable
|
<MyTable
|
||||||
:tableData="pageData.dtoList"
|
:tableData="pageData.dtoList"
|
||||||
@ -68,9 +66,9 @@ import { ElMessage } from "element-plus";
|
|||||||
const { proxy } = getCurrentInstance();
|
const { proxy } = getCurrentInstance();
|
||||||
const { D_BZ_SF } = proxy.$dict("D_BZ_SF"); //获取字典数据
|
const { D_BZ_SF } = proxy.$dict("D_BZ_SF"); //获取字典数据
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
tableData: {
|
contentText: {
|
||||||
type: Array,
|
type: String,
|
||||||
default: () => []
|
default: () => ''
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
const emit = defineEmits(['upadate'])
|
const emit = defineEmits(['upadate'])
|
||||||
|
@ -9,35 +9,14 @@
|
|||||||
<Search :searchArr="searchConfiger" @submit="onSearch"> </Search>
|
<Search :searchArr="searchConfiger" @submit="onSearch"> </Search>
|
||||||
<div class="tableCnt1 mb10 pl10 pr10">
|
<div class="tableCnt1 mb10 pl10 pr10">
|
||||||
<PageTitle title="发掘内容" style="color: #333">
|
<PageTitle title="发掘内容" style="color: #333">
|
||||||
<el-button type="primary" size="small" @click="handleData('add', '')">
|
|
||||||
<el-icon style="vertical-align: middle">
|
|
||||||
<CirclePlus />
|
|
||||||
</el-icon>
|
|
||||||
<span style="vertical-align: middle" @click="handleData('add', '')">新增</span>
|
|
||||||
</el-button>
|
|
||||||
<el-button type="primary" size="small" @click="isImport = true">
|
<el-button type="primary" size="small" @click="isImport = true">
|
||||||
<span style="vertical-align: middle">导入内容</span>
|
<span style="vertical-align: middle">导入内容</span>
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button type="danger" size="small" @click="deleteRow(idsTop)">
|
|
||||||
<el-icon style="vertical-align: middle">
|
|
||||||
<Delete />
|
|
||||||
</el-icon>
|
|
||||||
<span style="vertical-align: middle">批量删除</span>
|
|
||||||
</el-button>
|
|
||||||
</PageTitle>
|
</PageTitle>
|
||||||
<MyTable :tableData="pageData.tableData" :tableColumn="pageData.tableColumn" :tableHeight="pageData.tableHeight"
|
<div class="pl10 pt10 pb10 pr10" style="border: 1px dashed #ccc;color: #333;" :style="{height:pageData.tableHeight+'px'}">
|
||||||
:key="pageData.keyCount" :tableConfiger="pageData.tableConfiger0" :controlsWidth="pageData.controlsWidth"
|
{{ container.text }}
|
||||||
@chooseData="chooseDataTop">
|
</div>
|
||||||
<template #fjLx="{ row }">
|
|
||||||
<DictTag :tag="false" :value="row.fjLx" :options="D_GS_RQFJ_LX" />
|
|
||||||
</template>
|
|
||||||
<!-- 操作 -->
|
|
||||||
<template #controls="{ row }">
|
|
||||||
<el-link size="small" type="success" @click="handleData('edit', row)">编辑</el-link>
|
|
||||||
<el-link size="small" type="primary" @click="handleData('info', row)">查看</el-link>
|
|
||||||
<el-link size="small" type="danger" @click="deleteRow([row.id])">删除</el-link>
|
|
||||||
</template>
|
|
||||||
</MyTable>
|
|
||||||
<div class="ww100 flex just-center mt8">
|
<div class="ww100 flex just-center mt8">
|
||||||
<el-button type="primary" @click="intelligent">智能解析</el-button>
|
<el-button type="primary" @click="intelligent">智能解析</el-button>
|
||||||
</div>
|
</div>
|
||||||
@ -88,17 +67,18 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- 弹窗智能分析 -->
|
<!-- 弹窗智能分析 -->
|
||||||
<IntelligentParsing :tableData="pageData.tableData" ref="IntelligentParsingRef" @upadate="getModelList" />
|
<IntelligentParsing :contentText="container.text" ref="IntelligentParsingRef" @upadate="getModelList" />
|
||||||
<addForm ref="addFormDiloag" @onSearch="onSearch" />
|
<addForm ref="addFormDiloag" @onSearch="onSearch" />
|
||||||
<Model v-model="isShow" :type="chooselx" :ids="ids" @change="getModelList" :dic="{ D_GS_RQFJ_FXDJ }"></Model>
|
<Model v-model="isShow" :type="chooselx" :ids="ids" @change="getModelList" :dic="{ D_GS_RQFJ_FXDJ }"></Model>
|
||||||
<Export :show="isImport" lx="fjnr" @closeImport="isImport = false" @handleImport="getList" />
|
<!-- 文字解析 -->
|
||||||
|
<ExtractionText v-model="isImport" @change="getText"></ExtractionText>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { download } from "@/utils/request";
|
import { download } from "@/utils/request";
|
||||||
import Export from "@/components/export/index.vue";
|
import ExtractionText from "@/components/ExtractionText/index.vue";
|
||||||
import CheckBox from "@/components/checkBox/index.vue";
|
import CheckBox from "@/components/checkBox/index.vue";
|
||||||
import PageTitle from "@/components/aboutTable/PageTitle.vue";
|
import PageTitle from "@/components/aboutTable/PageTitle.vue";
|
||||||
import MyTable from "@/components/aboutTable/MyTable.vue";
|
import MyTable from "@/components/aboutTable/MyTable.vue";
|
||||||
@ -118,7 +98,8 @@ const { D_GS_RQFJ_LX, D_GS_RQFJ_FXDJ, D_BZ_SF, D_GS_RQFJ_FXLB } = proxy.$dict(
|
|||||||
"D_BZ_SF",
|
"D_BZ_SF",
|
||||||
"D_GS_RQFJ_FXLB"
|
"D_GS_RQFJ_FXLB"
|
||||||
); //获取字典数据
|
); //获取字典数据
|
||||||
|
const container = ref({})
|
||||||
|
const prsentText = ref(null)
|
||||||
const searchConfiger = ref([
|
const searchConfiger = ref([
|
||||||
{
|
{
|
||||||
label: "管辖部门",
|
label: "管辖部门",
|
||||||
@ -150,7 +131,6 @@ const btnsList = reactive([
|
|||||||
|
|
||||||
const chooselx = ref("");
|
const chooselx = ref("");
|
||||||
const isShow = ref(false);
|
const isShow = ref(false);
|
||||||
const idsTop = ref([]);
|
|
||||||
const ids = ref([]);
|
const ids = ref([]);
|
||||||
|
|
||||||
const addFormDiloag = ref();
|
const addFormDiloag = ref();
|
||||||
@ -236,7 +216,6 @@ const pageData = reactive({
|
|||||||
const onSearch = (val) => {
|
const onSearch = (val) => {
|
||||||
queryFrom.value = { ...val };
|
queryFrom.value = { ...val };
|
||||||
pageData.pageConfiger.pageCurrent = 1;
|
pageData.pageConfiger.pageCurrent = 1;
|
||||||
getList();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const changeNo = (val) => {
|
const changeNo = (val) => {
|
||||||
@ -248,20 +227,6 @@ const changeSize = (val) => {
|
|||||||
getModelList();
|
getModelList();
|
||||||
};
|
};
|
||||||
|
|
||||||
// 获取内容列表
|
|
||||||
const getList = () => {
|
|
||||||
pageData.tableConfiger.loading = true;
|
|
||||||
let data = { ...queryFrom.value };
|
|
||||||
let url = "/mosty-gsxt/tbGsxtRqfjNr/selectPage";
|
|
||||||
qcckGet(data, url)
|
|
||||||
.then((res) => {
|
|
||||||
pageData.tableData = res.records || [];
|
|
||||||
pageData.tableConfiger.loading = false;
|
|
||||||
})
|
|
||||||
.catch(() => {
|
|
||||||
pageData.tableConfiger.loading = false;
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
//获取模型识别列表
|
//获取模型识别列表
|
||||||
const getModelList = () => {
|
const getModelList = () => {
|
||||||
@ -278,31 +243,13 @@ const getModelList = () => {
|
|||||||
pageData.tableConfiger0.loading = false;
|
pageData.tableConfiger0.loading = false;
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
//新增- 编辑
|
|
||||||
const handleData = (type, row) => {
|
|
||||||
addFormDiloag.value.init(type, row);
|
|
||||||
};
|
|
||||||
// 智能解析
|
// 智能解析
|
||||||
const intelligent = () => {
|
const intelligent = () => {
|
||||||
IntelligentParsingRef.value.init();
|
IntelligentParsingRef.value.init();
|
||||||
};
|
};
|
||||||
|
|
||||||
// 选择数据
|
|
||||||
const chooseDataTop = (val) => {
|
|
||||||
if (Array.isArray(val)) idsTop.value = val.map((item) => item.id);
|
|
||||||
};
|
|
||||||
|
|
||||||
//删除操作
|
|
||||||
const deleteRow = (ids) => {
|
|
||||||
proxy.$confirm("确定要删除", "警告", { type: "warning" }).then(() => {
|
|
||||||
ids.forEach((id) => {
|
|
||||||
qcckGet({}, "/mosty-gsxt/tbGsxtRqfjNr/closeById/" + id).then((res) => {
|
|
||||||
ElMessage.success("删除成功");
|
|
||||||
getList();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
const deleteRowBottom = (id) => {
|
const deleteRowBottom = (id) => {
|
||||||
proxy.$confirm("确定要删除", "警告", { type: "warning" }).then(() => {
|
proxy.$confirm("确定要删除", "警告", { type: "warning" }).then(() => {
|
||||||
qcckDelete({}, "/mosty-gsxt/tbGsxtRqfjRy/" + id).then((res) => {
|
qcckDelete({}, "/mosty-gsxt/tbGsxtRqfjRy/" + id).then((res) => {
|
||||||
@ -340,6 +287,33 @@ const chooseType = (val) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// 提取数据
|
||||||
|
const getText = (val) =>{
|
||||||
|
prsentText.value = null; //先清空
|
||||||
|
container.value = val;
|
||||||
|
let obj = {
|
||||||
|
"model": "deepseek-reasoner",
|
||||||
|
"messages": [
|
||||||
|
{
|
||||||
|
"role": "system",
|
||||||
|
"content": "# 角色定位\n你是一名资深警务人员,尤其擅长对警情、案件、线索等非结构化文本数据进行阅读理解,并从中提取各种对象特征信息进行结构化,并总结各种对象之间的关联关系。\n## - person:人物 - id:唯一值 - name:姓名 - enName:英文姓名 - nickName:绰号 - aliasName:别名 - screenName:网名 - idcard:身份证号码 - phoneNo:手机号码 - bankCard:银行卡号 - passporNumber:护照号码 - permanentResidenceAddress:户籍地址 - residenceAddress:现住地址- jbxx:基本信息- id:唯一值 - xsmc:线索名称 - xslx:线索类型 - qbly:情报来源 - kssj:开始时间 - jssj:结束时间 - qtlx:群体类型 - qtmc:群体名称 - sjrs:设计人数 - sbdw:送报单- yjtq:语义提取 "
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"role": "user",
|
||||||
|
"content": "# 任务\n根据警情信息识别对象信息,以及对象之间的关联关系。最后以json形式输出,不要做任何解释。直接给出完整的json\n## 注意\n- 各种不同类型的对象分别用对象数组存储;\n- 对象之间的关系存储在relation数组中;\n\n# 警情信息\n - "
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"max_tokens": 4096,
|
||||||
|
"stream": false
|
||||||
|
}
|
||||||
|
obj.messages[0].content = obj.messages[0].content + "## 注意点\n- 地址信息能够根据上下文信息按照省、市、县、街道/乡镇、路名分段补全并标准化。例如:四川省 成都市 高新区 桂溪街道 交子大道11号\n- 对象之间的关联关系由对象类型、对象id、关系类型、目标对象类型、目标对象id 5个属性组成。\n"
|
||||||
|
// 拼接字典 线索类型:
|
||||||
|
let time = '时间必须按照 YYYY-MM-DD HH:mm:ss 的格式 \n'
|
||||||
|
obj.messages[0].content = obj.messages[0].content + time;
|
||||||
|
obj.messages[1].content = obj.messages[1].content + val.text
|
||||||
|
prsentText.value = obj;
|
||||||
|
}
|
||||||
|
|
||||||
const tabHeightFn = () => {
|
const tabHeightFn = () => {
|
||||||
pageData.tableHeight2 =
|
pageData.tableHeight2 =
|
||||||
window.innerHeight - searchBox.value.offsetHeight - 650;
|
window.innerHeight - searchBox.value.offsetHeight - 650;
|
||||||
@ -349,7 +323,6 @@ const tabHeightFn = () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
getList();
|
|
||||||
tabHeightFn();
|
tabHeightFn();
|
||||||
getModelList();
|
getModelList();
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user