feat:分析管理
This commit is contained in:
@@ -107,6 +107,8 @@ function handleDeviceData(res) {
|
||||
}
|
||||
|
||||
function handleDeviceStatus(res) {
|
||||
console.log(res)
|
||||
|
||||
if (res.deviceType === 'balance') {
|
||||
auncelList.value.forEach(item => {
|
||||
if (item.id === res.deviceId) {
|
||||
|
||||
@@ -75,7 +75,8 @@
|
||||
></zzjc-num-keyboard>
|
||||
<view v-if="selectedField.fillingWay == 'collect'" class="y-f">
|
||||
<view class="auncel" @click="selectAuncel">
|
||||
<view class="auncel-title"> {{ currentAuncel.code }}</view>
|
||||
<view class="code">{{ currentAuncel.code }}</view>
|
||||
<view class="auncel-title"> 杯号:{{ currentCupNum }} </view>
|
||||
<view class="auncel-weight">
|
||||
<view class="weight">
|
||||
<view
|
||||
@@ -379,26 +380,23 @@ const autoNextField = () => {
|
||||
const autoNextSample = () => {
|
||||
if (sampleDataList.value.length <= currentSampleIndex.value + 1) return
|
||||
const index = currentSampleIndex.value + 1
|
||||
groupFieldIndex.value = ''
|
||||
selectedField.value = {}
|
||||
switchSample(index, true)
|
||||
}
|
||||
|
||||
//手动切换样品
|
||||
const switchSample = async (index, autoFlag) => {
|
||||
if (!autoFlag) {
|
||||
const shouldContinue = await tools.showPromiseModal(
|
||||
'提示',
|
||||
`请确认样品【${currentSampleData.value.sampleCode}】数据已经保存,是否继续?`
|
||||
)
|
||||
if (!shouldContinue) {
|
||||
return // 用户点了取消,直接退出
|
||||
}
|
||||
}
|
||||
// if (!autoFlag) {
|
||||
// const shouldContinue = await tools.showPromiseModal(
|
||||
// '提示',
|
||||
// `请确认样品【${currentSampleData.value.sampleCode}】数据已经保存,是否继续?`
|
||||
// )
|
||||
// if (!shouldContinue) {
|
||||
// return // 用户点了取消,直接退出
|
||||
// }
|
||||
// }
|
||||
//重置天平归0
|
||||
weightDataIsToZero.value = false
|
||||
if (index === currentSampleIndex.value) return
|
||||
setValueToSample()
|
||||
currentSampleIndex.value = index
|
||||
// 如果为0,意味着尚未初始化
|
||||
if (menuHeight.value === 0 || menuItemHeight.value === 0) {
|
||||
@@ -670,7 +668,7 @@ const saveAuncelData = () => {
|
||||
weightDataIsToZero.value = false
|
||||
}, 100)
|
||||
}
|
||||
const dynamicFormData = {}
|
||||
let dynamicFormData = reactive({})
|
||||
const saveDetail = async () => {
|
||||
//检查杯号
|
||||
if (!checkBh()) return
|
||||
@@ -713,7 +711,7 @@ const saveDetail = async () => {
|
||||
}
|
||||
|
||||
await nx.$api.assayTask.saveBatchSmpleAndQcAnalysis(params)
|
||||
getSampleAnalysisByTaskId()
|
||||
// getSampleAnalysisByTaskId()
|
||||
autoNextSample()
|
||||
}
|
||||
// 计算表格列平均值
|
||||
@@ -759,10 +757,6 @@ function setValueToSample() {
|
||||
) {
|
||||
currentSampleData.value[item.fieldIndex].value = item.value
|
||||
}
|
||||
// 初始化的时候保存杯号到样品中后续自动生成杯号用
|
||||
if (item.title === cupNumKey && currentSampleIndex.value == 0) {
|
||||
currentSampleData.value.cupNum = item.value
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
@@ -782,7 +776,7 @@ const submitTask = () => {
|
||||
|
||||
nx.$api.assayTask.submitTask(params).then(res => {
|
||||
uni.navigateTo({
|
||||
url: '/pages/analysis/sample/sample-report'
|
||||
url: '/pages/analysis/sample/sample-report-search'
|
||||
})
|
||||
})
|
||||
}
|
||||
@@ -792,23 +786,22 @@ const submitTask = () => {
|
||||
//自动生成杯号(仅顺序称重):第一杯:手填,后续杯 = 上一杯 + 1
|
||||
const autoGenerateCupNum = () => {
|
||||
let cupNum = 0
|
||||
let current = currentSampleIndex.value
|
||||
let currentIndex = currentSampleIndex.value
|
||||
//第一杯
|
||||
if (current === 0) return
|
||||
if (currentIndex === 0) return
|
||||
//取上一个样品的杯号
|
||||
const sample = sampleDataList.value[current - 1]
|
||||
cupNum = sample.cupNum
|
||||
const sample = sampleDataList.value[currentIndex - 1]
|
||||
cupNum = sample[cupNumFieldIndex.value].value
|
||||
//杯号赋值到当前样品
|
||||
putCupNum(Number(cupNum) + 1, current, Number(cupNum))
|
||||
putCupNum(Number(cupNum) + 1, currentIndex, Number(cupNum))
|
||||
}
|
||||
|
||||
const putCupNum = (cupNum, sampleIndex, lastCupNum) => {
|
||||
sampleDataList.value[sampleIndex].cupNum = cupNum
|
||||
for (const fields of fieldGroup.value) {
|
||||
if (typeof fields === 'undefined') continue
|
||||
//杯号
|
||||
for (const field of fields.fields) {
|
||||
if (field.title === cupNumKey) {
|
||||
if (field.fieldIndex === cupNumFieldIndex.value) {
|
||||
if (typeof field.value === 'undefined' || field.value === null || field.value === '') {
|
||||
field.value = cupNum
|
||||
return true
|
||||
@@ -817,33 +810,32 @@ const putCupNum = (cupNum, sampleIndex, lastCupNum) => {
|
||||
}
|
||||
}
|
||||
//处理筛上筛下
|
||||
if (lastCupNum && lastCupNum === sampleIndex) {
|
||||
//上一个杯号 == 默认杯号
|
||||
cupNum = sampleIndex * 2 + 1
|
||||
}
|
||||
for (const fields of fieldGroup.value) {
|
||||
if (typeof fields === 'undefined') continue
|
||||
//杯号-筛下
|
||||
for (const field of fields.fields) {
|
||||
if (field.dicKey === cupNumKey + '_down') {
|
||||
if (typeof field.value === 'undefined' || field.value === null || field.value === '') {
|
||||
field.value = cupNum
|
||||
cupNum++
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
//杯号-筛上
|
||||
for (const field of fields.fields) {
|
||||
if (field.dicKey === cupNumKey + '_up') {
|
||||
if (typeof field.value === 'undefined' || field.value === null || field.value === '') {
|
||||
field.value = cupNum
|
||||
return true
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return false
|
||||
// if (lastCupNum && lastCupNum === sampleIndex) {
|
||||
// //上一个杯号 == 默认杯号
|
||||
// cupNum = sampleIndex * 2 + 1
|
||||
// }
|
||||
// for (const fields of fieldGroup.value) {
|
||||
// if (typeof fields === 'undefined') continue
|
||||
// //杯号-筛下
|
||||
// for (const field of fields.fields) {
|
||||
// if (field.dicKey === cupNumKey + '_down') {
|
||||
// if (typeof field.value === 'undefined' || field.value === null || field.value === '') {
|
||||
// field.value = cupNum
|
||||
// cupNum++
|
||||
// break
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
// //杯号-筛上
|
||||
// for (const field of fields.fields) {
|
||||
// if (field.dicKey === cupNumKey + '_up') {
|
||||
// if (typeof field.value === 'undefined' || field.value === null || field.value === '') {
|
||||
// field.value = cupNum
|
||||
// return true
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
}
|
||||
|
||||
const loadConRecoveryList = () => {
|
||||
@@ -880,6 +872,8 @@ const activeAssayTypeKey = ref('')
|
||||
const activeAssayTypeIndex = ref(0)
|
||||
//元素结果范围
|
||||
let conRangeElementAnalysisList = ref([])
|
||||
// 杯号fieldIndex
|
||||
const cupNumFieldIndex = ref('')
|
||||
const currentAssayType = computed(() => {
|
||||
return assayGroups.value.find(item => item.value === activeAssayTypeKey.value)
|
||||
})
|
||||
@@ -894,12 +888,22 @@ watch(
|
||||
() => currentAssayType.value,
|
||||
() => {
|
||||
sampleDataList.value = currentAssayType.value.tableData
|
||||
fieldGroup.value = groupByField(currentAssayType.value.columns)
|
||||
fieldGroup.value = groupByField(currentAssayType.value.columns, cupNumFieldIndex)
|
||||
|
||||
setValueToField()
|
||||
// getDomHeight()
|
||||
activeCollapses.value = fieldGroup.value.map((_, index) => index)
|
||||
}
|
||||
)
|
||||
const currentCupNum = computed(() => {
|
||||
for (const item of fieldGroup.value) {
|
||||
const field = item.fields.find(field => field.fieldIndex === cupNumFieldIndex.value)
|
||||
if (field) {
|
||||
return field.value
|
||||
}
|
||||
}
|
||||
return null
|
||||
})
|
||||
const currentGroup = computed(() => {
|
||||
if (!currentAssayType.value || curParameterKey.value === 'all') {
|
||||
return fieldGroup.value
|
||||
@@ -936,10 +940,11 @@ function handleAssayTypeChange({ index, value }) {
|
||||
}
|
||||
// 获取任务指派单数据
|
||||
async function getSampleAnalysisByTaskId() {
|
||||
const { assayTaskAnalysisDataList, configAssayMethodProjectRangeList, businessAssayTasNo } =
|
||||
const { assayTaskAnalysisDataList, configAssayMethodProjectRangeList, businessAssayTasNo, formValue } =
|
||||
await nx.$api.assayTask.batchSampleAndQcAnalysisByTaskId(taskId.value)
|
||||
title.value = '样品分析-任务指派单:' + businessAssayTasNo
|
||||
// 处理分析数据
|
||||
|
||||
assayGroups.value = assayTaskAnalysisDataList.map(group => {
|
||||
// 必须深拷贝 datas!防止多个表格共享引用
|
||||
const tableData = JSON.parse(JSON.stringify(group.datas || []))
|
||||
@@ -955,6 +960,7 @@ async function getSampleAnalysisByTaskId() {
|
||||
: []
|
||||
}
|
||||
})
|
||||
dynamicFormData = formValue ? JSON.parse(formValue) : {}
|
||||
// 默认激活第一个 类型
|
||||
if (!activeAssayTypeKey.value) {
|
||||
activeAssayTypeKey.value = assayGroups.value.length > 0 ? assayGroups.value[0].value : ''
|
||||
@@ -1120,19 +1126,7 @@ const listenNumKeyboard = () => {
|
||||
//自动补全小数位数
|
||||
const decimalPosition = selectedField.value.decimalPosition || 0
|
||||
let val = res.val
|
||||
//判断val小数位,如果小于设定位数,则补全
|
||||
if (decimalPosition > 0) {
|
||||
if (val === '') val = '0'
|
||||
if (typeof val === 'number') val += ''
|
||||
let dotLen = 0
|
||||
if (val.indexOf('.') > 0) dotLen = val.length - val.indexOf('.') - 1
|
||||
else val += '.'
|
||||
while (dotLen < decimalPosition) {
|
||||
dotLen++
|
||||
val += '0'
|
||||
}
|
||||
}
|
||||
selectedField.value.value = val
|
||||
selectedField.value.value = handleRoundFiveNumber(val, decimalPosition)
|
||||
const dicKey = selectedField.value.dicKey
|
||||
if (dicKey && dicKey === 'bh_down') {
|
||||
autoFillBhUp(val)
|
||||
@@ -1335,11 +1329,18 @@ onBackPress(() => {
|
||||
background-position: center;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
position: relative;
|
||||
.code {
|
||||
position: absolute;
|
||||
top: 10px;
|
||||
left: 50px;
|
||||
}
|
||||
}
|
||||
|
||||
.auncel-title {
|
||||
flex: 3;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
font-size: 32px;
|
||||
|
||||
@@ -101,7 +101,7 @@ const formFields = ref([])
|
||||
const staticFormSchema = [
|
||||
{ label: '指派单号', fieldKey: 'businessAssayTaskId', hidden: true },
|
||||
{ type: 'title', value: '分析原始记录单' },
|
||||
{ label: '检测方法', type: 'Input', fieldKey: 'configAssayMethodName', disabled: true },
|
||||
{ label: '检测方法', type: 'Input', fieldKey: 'configAssayMethodName' },
|
||||
{ label: '分析人', type: 'Input', fieldKey: 'assayOperator', disabled: true },
|
||||
{ label: '检测时间', type: 'date', fieldKey: 'assayTime' }
|
||||
]
|
||||
@@ -294,10 +294,11 @@ function getDynamicFormSchemaFormData(obj) {
|
||||
}
|
||||
// 检查动态字段值在空白样或者标样的(影响计算配置字段)中是否变化
|
||||
function checkPropertyEquality() {
|
||||
if (configQCSampleMethodInfos.value.length === 0) return false
|
||||
for (const config of configQCSampleMethodInfos.value) {
|
||||
const target = config.target
|
||||
if (!target) continue
|
||||
let allColumns = tabs.value.flatMap(tab => tab.columns)
|
||||
for (const column of allColumns) {
|
||||
const formula = column.formula
|
||||
if (!formula) continue
|
||||
const target = formula.split(':')[1]
|
||||
const originalValue = dynamicFormData.value[target]
|
||||
const currentValue = realFormData.value[target]
|
||||
console.log('checkPropertyEquality', originalValue, currentValue)
|
||||
|
||||
Reference in New Issue
Block a user