You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
4378 lines
150 KiB
4378 lines
150 KiB
<template>
|
|
<div class="mod-config">
|
|
|
|
<!-- 条件查询 -->
|
|
<el-card :class="['search-card', { 'collapsed': !searchExpanded }]" shadow="hover">
|
|
<div slot="header" class="search-header">
|
|
<div class="header-left">
|
|
<i class="el-icon-search"></i>
|
|
<span class="header-title">Search</span>
|
|
</div>
|
|
<div class="header-right">
|
|
<el-button
|
|
type="text"
|
|
size="small"
|
|
@click="toggleSearchExpand"
|
|
class="collapse-btn">
|
|
<i :class="searchExpanded ? 'el-icon-arrow-up' : 'el-icon-arrow-down'"></i>
|
|
{{ searchExpanded ? '收起' : '展开' }}
|
|
</el-button>
|
|
</div>
|
|
</div>
|
|
|
|
<el-form
|
|
:inline="true"
|
|
label-position="top"
|
|
:model="searchData"
|
|
class="search-form"
|
|
@keyup.enter.native="getDataList">
|
|
|
|
<!-- 所有查询条件 - 可展开/收起 -->
|
|
<template v-if="searchExpanded">
|
|
<!-- 第一行:基础单据信息 -->
|
|
<el-row :gutter="16">
|
|
<el-col :span="4">
|
|
<el-form-item label="BU">
|
|
<el-select v-model="searchData.buDesc" placeholder="请选择BU" clearable>
|
|
<el-option
|
|
v-for="i in userBuList"
|
|
:key="i.buNo"
|
|
:label="i.buDesc"
|
|
:value="i.buDesc">
|
|
</el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="检验单号">
|
|
<el-input v-model="searchData.inspectionNo" placeholder="请输入检验单号" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="销售订单">
|
|
<el-input v-model="searchData.poOrderNo" placeholder="请输入销售订单" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="客户编码">
|
|
<el-input v-model="searchData.customerNo" placeholder="请输入客户编码" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="客户名称">
|
|
<el-input v-model="searchData.customerName" placeholder="请输入客户名称" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
</el-row>
|
|
|
|
<!-- 第二行:物料信息 -->
|
|
<el-row :gutter="16">
|
|
<el-col :span="4">
|
|
<el-form-item label="物料编码">
|
|
<el-input v-model="searchData.partNo" placeholder="请输入物料编码" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="物料名称">
|
|
<el-input v-model="searchData.partDesc" placeholder="请输入物料名称" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="规格型号">
|
|
<el-input v-model="searchData.spec" placeholder="请输入规格型号" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
</el-row>
|
|
|
|
<!-- 第三行:检验相关信息 -->
|
|
<el-row :gutter="16">
|
|
<el-col :span="4">
|
|
<el-form-item label="检验结论">
|
|
<el-select v-model="searchData.inspectionResult" placeholder="请选择" clearable>
|
|
<el-option label="合格" value="合格">
|
|
<span style="color: #67C23A">✓ 合格</span>
|
|
</el-option>
|
|
<el-option label="不合格" value="不合格">
|
|
<span style="color: #F56C6C">✗ 不合格</span>
|
|
</el-option>
|
|
<el-option label="免检" value="免检">
|
|
<span style="color: #909399">◉ 免检</span>
|
|
</el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="处置措施">
|
|
<el-select v-model="searchData.disposalMeasures" placeholder="请选择" clearable>
|
|
<el-option
|
|
v-for="i in disposalMeasuresOptions"
|
|
:key="i.id"
|
|
:label="i.disposalMeasures"
|
|
:value="i.disposalMeasures">
|
|
</el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="状态">
|
|
<el-select v-model="searchData.states" multiple collapse-tags placeholder="请选择状态" class="status-select">
|
|
<el-option label="未开始" value="未开始"></el-option>
|
|
<el-option label="待检验" value="待检验"></el-option>
|
|
<el-option label="待审核" value="待审核"></el-option>
|
|
<el-option label="已完成" value="已完成"></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="5">
|
|
<el-form-item label="质检员">
|
|
<el-input v-model="searchData.inspectorName" placeholder="请输入质检员姓名" clearable></el-input>
|
|
</el-form-item>
|
|
</el-col>
|
|
</el-row>
|
|
|
|
<!-- 第四行:日期信息 -->
|
|
<el-row :gutter="16">
|
|
<el-col :span="9">
|
|
<el-form-item label="送检日期">
|
|
<el-date-picker
|
|
v-model="searchData.startDate2"
|
|
type="date"
|
|
value-format='yyyy-MM-dd'
|
|
format='yyyy-MM-dd'
|
|
placeholder="开始日期"
|
|
style="width: 44%">
|
|
</el-date-picker>
|
|
<span style="margin: 0 6px; color: #DCDFE6;">~</span>
|
|
<el-date-picker
|
|
v-model="searchData.endDate2"
|
|
type="date"
|
|
value-format='yyyy-MM-dd'
|
|
format='yyyy-MM-dd'
|
|
placeholder="结束日期"
|
|
style="width: 44%">
|
|
</el-date-picker>
|
|
</el-form-item>
|
|
</el-col>
|
|
<el-col :span="9">
|
|
<el-form-item label="检验日期">
|
|
<el-date-picker
|
|
v-model="searchData.startDate"
|
|
type="date"
|
|
value-format='yyyy-MM-dd'
|
|
format='yyyy-MM-dd'
|
|
placeholder="开始日期"
|
|
style="width: 44%">
|
|
</el-date-picker>
|
|
<span style="margin: 0 6px; color: #DCDFE6;">~</span>
|
|
<el-date-picker
|
|
v-model="searchData.endDate"
|
|
type="date"
|
|
value-format='yyyy-MM-dd'
|
|
format='yyyy-MM-dd'
|
|
placeholder="结束日期"
|
|
style="width: 44%">
|
|
</el-date-picker>
|
|
</el-form-item>
|
|
</el-col>
|
|
</el-row>
|
|
</template>
|
|
|
|
<!-- 操作按钮区域 -->
|
|
<el-row :gutter="16">
|
|
<el-col :span="24">
|
|
<div class="search-actions">
|
|
<div class="action-left">
|
|
<el-button
|
|
v-if="!authSearch"
|
|
type="primary"
|
|
icon="el-icon-search"
|
|
@click="getDataList">
|
|
查询
|
|
</el-button>
|
|
<el-button
|
|
icon="el-icon-refresh-left"
|
|
@click="resetSearch">
|
|
重置
|
|
</el-button>
|
|
</div>
|
|
<div class="action-right">
|
|
<el-button
|
|
v-if="!authCheck"
|
|
type="success"
|
|
icon="el-icon-check"
|
|
@click="submitResult">
|
|
审核
|
|
</el-button>
|
|
<el-button
|
|
v-if="!authDelete"
|
|
type="danger"
|
|
icon="el-icon-delete"
|
|
@click="deleteModal">
|
|
删除
|
|
</el-button>
|
|
<el-button
|
|
v-if="!authOverLoad"
|
|
type="warning"
|
|
icon="el-icon-refresh"
|
|
:loading="overLoading"
|
|
@click="overLoadModal">
|
|
任务重载
|
|
</el-button>
|
|
<download-excel
|
|
:fields="fields()"
|
|
:data="exportData"
|
|
type="xls"
|
|
:name="exportName"
|
|
:header="exportHeader"
|
|
:footer="exportFooter"
|
|
:fetch="createExportData"
|
|
:before-generate="startDownload"
|
|
:before-finish="finishDownload"
|
|
worksheet="导出信息"
|
|
class="el-button el-button--primary el-button--medium">
|
|
<i class="el-icon-download"></i>
|
|
导出
|
|
</download-excel>
|
|
</div>
|
|
</div>
|
|
</el-col>
|
|
</el-row>
|
|
</el-form>
|
|
</el-card>
|
|
|
|
<!-- 检验记录展示列表 -->
|
|
<el-table
|
|
:height="height"
|
|
:data="dataList"
|
|
border
|
|
ref="OQCTable"
|
|
show-summary
|
|
:summary-method="getSummaries"
|
|
@row-click="FQASClickRow"
|
|
@selection-change="selectionFQAS"
|
|
style="width: 100%;">
|
|
<el-table-column
|
|
type="selection"
|
|
header-align="center"
|
|
align="center"
|
|
width="50">
|
|
</el-table-column>
|
|
<el-table-column
|
|
prop="state"
|
|
header-align="center"
|
|
align="center"
|
|
label="状态">
|
|
<template slot-scope="scope">
|
|
<div :style="{fontWeight:'bold', color: scope.row.state === '待检验' ? 'red' : scope.row.state === '待审核' ? '#ffa500e0' : scope.row.state === '已完成' ? '#3ac252' : ''}">
|
|
{{ scope.row.state }}
|
|
</div>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
v-for="(item,index) in columnList1" :key="index"
|
|
:sortable="item.columnSortable"
|
|
:prop="item.columnProp"
|
|
:header-align="item.headerAlign"
|
|
:show-overflow-tooltip="item.showOverflowTooltip"
|
|
:align="item.align"
|
|
:fixed="item.fixed===''?false:item.fixed"
|
|
:min-width="item.columnWidth"
|
|
:label="item.columnLabel">
|
|
<template slot-scope="scope">
|
|
<div v-if="item.columnProp === 'inspectionResult' && scope.row.inspectionResult === '不合格' && scope.row.disposalMeasures === '拒收退回'">
|
|
<span v-if="!item.columnHidden" style="color: red"> {{ scope.row[item.columnProp] }}</span>
|
|
<span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px"/></span>
|
|
</div>
|
|
<div v-else>
|
|
<span v-if="!item.columnHidden"> {{ scope.row[item.columnProp] }}</span>
|
|
<span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px"/></span>
|
|
</div>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
fixed="right"
|
|
header-align="center"
|
|
align="center"
|
|
width="100"
|
|
label="操作">
|
|
<template slot-scope="scope">
|
|
<el-link style="cursor: pointer" v-if="!authDetail && scope.row.state === '未开始'" @click="actionModal(scope.row)">开始检验</el-link>
|
|
<el-link style="cursor: pointer" v-if="!authDetail && scope.row.state !== '未开始'" @click="detailModal(scope.row)">检验单</el-link>
|
|
<el-dropdown trigger="click">
|
|
<el-link style="cursor: pointer;font-size: 12px">更多</el-link>
|
|
<el-dropdown-menu slot="dropdown">
|
|
<el-dropdown-item v-if="!authFile" @click.native="getFileContentData(scope.row)">工作文件</el-dropdown-item>
|
|
<el-dropdown-item v-if="!authChange && scope.row.state === '待检验'" @click.native="changeInspectionModal(scope.row)">更改检验方式</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</el-dropdown>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
|
|
<!-- 分页-->
|
|
<el-pagination
|
|
style="margin-top: 0px"
|
|
@size-change="sizeChangeHandle"
|
|
@current-change="currentChangeHandle"
|
|
:current-page="pageIndex"
|
|
:page-sizes="[20, 50, 100, 200, 500]"
|
|
:page-size="pageSize"
|
|
:total="totalPage"
|
|
layout="total, sizes, prev, pager, next, jumper">
|
|
</el-pagination>
|
|
|
|
<!-- 检验单详情页 -->
|
|
<el-dialog
|
|
:title="'检验明细清单-' + (detailData.inspectionNo || '')"
|
|
:close-on-click-modal="false"
|
|
v-drag
|
|
:visible.sync="detailInformationFlag"
|
|
width="1200px"
|
|
top="2vh"
|
|
custom-class="oqc-inspection-dialog">
|
|
<!-- 单据信息卡片 -->
|
|
<div class="inspection-info-card">
|
|
<div class="info-section">
|
|
<div class="section-title">
|
|
<i class="el-icon-document"></i>
|
|
<span>检验单信息</span>
|
|
</div>
|
|
<!-- 第一行:物料信息 + 人员信息 -->
|
|
<el-row :gutter="12" class="info-row">
|
|
<el-col :span="3">
|
|
<div class="info-item">
|
|
<label>物料编码</label>
|
|
<el-input v-model="detailData.partNo" disabled size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="6">
|
|
<div class="info-item">
|
|
<label>物料名称</label>
|
|
<el-input v-model="detailData.partDesc" disabled size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="3">
|
|
<div class="info-item">
|
|
<label>规格型号</label>
|
|
<el-input v-model="detailData.spec" disabled size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="2">
|
|
<div class="info-item">
|
|
<label>计量单位</label>
|
|
<el-input v-model="detailData.umName" disabled size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="4">
|
|
<div class="info-item">
|
|
<label>
|
|
<span v-if="detailData.submitFlag === 'Y'">协同人员</span>
|
|
<a v-else style="cursor: pointer" @click="getOperatorList">协同人员</a>
|
|
</label>
|
|
<el-input v-model="detailData.operatorName" readonly size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="6">
|
|
<div class="info-item">
|
|
<label>
|
|
<span v-if="detailData.submitFlag === 'Y'">责任人(供应商)</span>
|
|
<a v-else style="cursor: pointer" @click="getBaseList(509)">责任人(供应商)</a>
|
|
</label>
|
|
<el-input v-model="detailData.responsiblePerson" :readonly="detailData.submitFlag === 'Y'" size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
</el-row>
|
|
<!-- 第二行:数量信息 -->
|
|
<el-row :gutter="12" class="info-row" style="margin-top: 12px">
|
|
<el-col :span="4">
|
|
<div class="info-item">
|
|
<label>发货数量</label>
|
|
<el-input-number :controls="false" :step="0" v-model="detailData.rollQty" disabled size="small" style="width: 100%"></el-input-number>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="4">
|
|
<div class="info-item">
|
|
<label>送检数量</label>
|
|
<el-input-number :controls="false" :step="0" v-model="detailData.rollCount" size="small" style="width: 100%"></el-input-number>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="4">
|
|
<div class="info-item">
|
|
<label>抽样数量</label>
|
|
<el-input-number :controls="false" :step="0" v-model="detailData.samplingQty" size="small" style="width: 100%"></el-input-number>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="4">
|
|
<div class="info-item">
|
|
<label>合格数量</label>
|
|
<el-input-number :controls="false" :step="0" min="0" v-if="detailData.submitFlag === 'Y'" v-model="detailData.passQty" disabled size="small" style="width: 100%"></el-input-number>
|
|
<el-input-number :controls="false" :step="0" min="0" v-else @input="handleInput(detailData.passQty,2)" v-model="detailData.passQty" size="small" style="width: 100%"></el-input-number>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="4">
|
|
<div class="info-item">
|
|
<label>不合格数量</label>
|
|
<el-input-number :controls="false" :step="0" min="0" v-model="detailData.notPassQty" disabled size="small" style="width: 100%"></el-input-number>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="4">
|
|
<div class="info-item">
|
|
<label>不合格项目数量</label>
|
|
<el-input-number :controls="false" :step="0" v-if="detailData.submitFlag === 'Y'" v-model="detailData.unqualifiedQty" disabled size="small" style="width: 100%"></el-input-number>
|
|
<el-input-number :controls="false" :step="0" v-else @input="handleInput(detailData.unqualifiedQty,1)" v-model="detailData.unqualifiedQty" size="small" style="width: 100%"></el-input-number>
|
|
</div>
|
|
</el-col>
|
|
</el-row>
|
|
</div>
|
|
|
|
<div class="info-section" style="margin-top: 10px">
|
|
<div class="section-title">
|
|
<i class="el-icon-finished"></i>
|
|
<span>检验结论</span>
|
|
</div>
|
|
<el-row :gutter="12" class="info-row">
|
|
<el-col :span="3">
|
|
<div class="info-item">
|
|
<label>检验结论</label>
|
|
<el-select v-if="detailData.submitFlag === 'Y'" v-model="detailData.inspectionResult" disabled size="small" placeholder="请选择" style="width: 100%">
|
|
<el-option label="合格" value="合格"></el-option>
|
|
<el-option label="不合格" value="不合格"></el-option>
|
|
</el-select>
|
|
<el-select v-else v-model="detailData.inspectionResult" @change="resultChange" size="small" placeholder="请选择" style="width: 100%">
|
|
<el-option label="合格" value="合格"></el-option>
|
|
<el-option label="不合格" value="不合格"></el-option>
|
|
</el-select>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="7">
|
|
<div class="info-item">
|
|
<label>质检备注</label>
|
|
<el-input v-if="detailData.submitFlag === 'Y'" v-model="detailData.inspectionRemark" disabled size="small"></el-input>
|
|
<el-input v-else v-model="detailData.inspectionRemark" size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="3" v-show="detailData.inspectionResult === '不合格'">
|
|
<div class="info-item">
|
|
<label>处置措施</label>
|
|
<el-select v-if="detailData.submitFlag === 'Y'" clearable v-model="detailData.disposalMeasures" disabled size="small" style="width: 100%">
|
|
<el-option
|
|
v-for = "i in disposalMeasuresOptions"
|
|
:key = "i.id"
|
|
:label = "i.disposalMeasures"
|
|
:value = "i.disposalMeasures">
|
|
</el-option>
|
|
</el-select>
|
|
<el-select v-else clearable v-model="detailData.disposalMeasures" size="small" style="width: 100%">
|
|
<el-option
|
|
v-for = "i in disposalMeasuresOptions"
|
|
:key = "i.id"
|
|
:label = "i.disposalMeasures"
|
|
:value = "i.disposalMeasures">
|
|
</el-option>
|
|
</el-select>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="7" v-show="detailData.inspectionResult === '不合格'">
|
|
<div class="info-item">
|
|
<label>处置说明</label>
|
|
<el-input v-if="detailData.submitFlag === 'Y'" v-model="detailData.disposalRemark" disabled size="small"></el-input>
|
|
<el-input v-else v-model="detailData.disposalRemark" size="small"></el-input>
|
|
</div>
|
|
</el-col>
|
|
</el-row>
|
|
</div>
|
|
|
|
<!-- 操作按钮区域 -->
|
|
<div class="action-buttons">
|
|
<div class="left-actions">
|
|
<el-button type="info" size="small" @click="getFileContentData(detailData)" icon="el-icon-folder-opened">
|
|
工作文件
|
|
</el-button>
|
|
<el-button type="warning" size="small" @click="subDetailUpload" icon="el-icon-upload2">
|
|
明细导入
|
|
</el-button>
|
|
</div>
|
|
<div class="right-actions">
|
|
<el-button type="success" size="small" @click="openItemOperationDialog" icon="el-icon-setting">
|
|
项目导入
|
|
</el-button>
|
|
<el-button type="primary" size="small" @click="openTemplateImportDialog" icon="el-icon-download">
|
|
模板导入
|
|
</el-button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- 检验项目列表 -->
|
|
<div class="inspection-table-wrapper">
|
|
<div class="table-header">
|
|
<span class="table-title">
|
|
<i class="el-icon-tickets"></i>
|
|
检验内容
|
|
</span>
|
|
</div>
|
|
<el-table
|
|
:height="435"
|
|
:data="detailList"
|
|
border
|
|
stripe
|
|
:row-style="rowDetailStyle"
|
|
@row-click="OQCDetailClickRow"
|
|
style="width: 100%;"
|
|
class="inspection-table">
|
|
<el-table-column
|
|
prop=""
|
|
header-align="center"
|
|
align="center"
|
|
min-width="80"
|
|
label="操作">
|
|
<template slot-scope="scope">
|
|
<el-button icon="el-icon-picture" :type="scope.row.detailImageNum > 0 ? 'success' : 'primary'" size="mini" @click="uploadImageModal(scope.row)" title="上传图片"></el-button>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
v-for="(item,index) in detailColumnList" :key="index"
|
|
:sortable="item.columnSortable"
|
|
:prop="item.columnProp"
|
|
:header-align="item.headerAlign"
|
|
:show-overflow-tooltip="item.showOverflowTooltip"
|
|
:align="item.align"
|
|
:fixed="item.fixed===''?false:item.fixed"
|
|
:min-width="item.columnWidth"
|
|
:label="item.columnLabel">
|
|
<template slot-scope="scope">
|
|
<span v-if="!item.columnHidden">{{scope.row[item.columnProp]}}</span>
|
|
<span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px"/></span>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
prop=""
|
|
header-align="center"
|
|
align="right"
|
|
min-width="80"
|
|
label="实测值">
|
|
<template slot-scope="scope">
|
|
<el-input :ref="`textValue${scope.$index}`" v-if="scope.row.valueTypeDb === 'N'" v-model="scope.row.numberValue" @keyup.enter.native="focusNextInput(scope.$index, 'textValue')" type="number" style="height: 11px; width: 98%"></el-input>
|
|
<el-input :ref="`textValue${scope.$index}`" v-else v-model="scope.row.textValue" @keyup.enter.native="focusNextInput(scope.$index, 'textValue')" style="height: 11px; width: 98%"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
prop=""
|
|
header-align="center"
|
|
align="center"
|
|
min-width="80"
|
|
label="检验明细">
|
|
<template slot-scope="scope">
|
|
<el-button v-if="scope.row.subDetailRecordNum > 0" type="success" @click="subDetailModal(scope.row) ">点击输入</el-button>
|
|
<el-button v-else type="primary" @click="subDetailModal(scope.row)">点击输入</el-button>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
prop=""
|
|
header-align="center"
|
|
align="right"
|
|
min-width="80"
|
|
label="抽样数量">
|
|
<template slot-scope="scope">
|
|
<el-input class="inlineNumber numInput" v-if="detailData.submitFlag === 'Y'" v-model="scope.row.samplingQty" disabled type="number" style="height: 11px; width: 98%"></el-input>
|
|
<el-input class="inlineNumber numInput" v-else :ref="`samplingQty${scope.$index}`" v-model="scope.row.samplingQty" type="number" @keyup.enter.native="focusNextInput(scope.$index, 'samplingQty')" style="height: 11px; width: 98%"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
prop=""
|
|
header-align="center"
|
|
align="right"
|
|
min-width="80"
|
|
label="不合格数量">
|
|
<template slot-scope="scope">
|
|
<el-input class="inlineNumber numInput" v-if="detailData.submitFlag === 'Y'" v-model="scope.row.unqualifiedQuantity" disabled type="number" style="height: 11px; width: 98%"></el-input>
|
|
<el-input class="inlineNumber numInput" v-else :ref="`unqualifiedQuantity${scope.$index}`" v-model="scope.row.unqualifiedQuantity" type="number" @keyup.enter.native="focusNextInput(scope.$index, 'unqualifiedQuantity')" style="height: 11px; width: 98%"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
prop=""
|
|
header-align="center"
|
|
align="right"
|
|
min-width="90"
|
|
label="项目检验结论">
|
|
<template slot-scope="scope">
|
|
<el-select :class="{redElSelect:scope.row.itemResult === 'N', greenElSelect:scope.row.itemResult === 'Y'}" v-if="detailData.submitFlag === 'Y'" v-model="scope.row.itemResult" disabled style="height: 11px;padding: 0px" >
|
|
<el-option label="合格" value="Y" style="color: green"></el-option>
|
|
<el-option label="不合格" value="N" style="color: red"></el-option>
|
|
</el-select>
|
|
<el-select :class="{redElSelect:scope.row.itemResult === 'N', greenElSelect:scope.row.itemResult === 'Y'}" v-else v-model="scope.row.itemResult" style="height: 11px;padding: 0px" placeholder="合格">
|
|
<el-option label="合格" value="Y" style="color: green"></el-option>
|
|
<el-option label="不合格" value="N" style="color: red"></el-option>
|
|
</el-select>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</div>
|
|
|
|
<!-- 底部操作按钮 -->
|
|
<div class="dialog-footer">
|
|
<el-button v-if="detailData.state === '待检验'" type="primary" :loading="transferLoadFlag" @click="Transfer('1')">应用</el-button>
|
|
<el-button v-if="detailData.state === '待检验' || detailData.state === '待审核'" type="primary" :loading="transferLoadFlag" @click="Transfer('2')">保存</el-button>
|
|
<el-button @click="detailInformationFlag=false">关闭</el-button>
|
|
</div>
|
|
</el-dialog>
|
|
|
|
<!-- 文件清单 -->
|
|
<el-dialog title="文件清单" :close-on-click-modal="false" v-drag :visible.sync="fileFlag" width="900px">
|
|
<el-tabs v-model="fileActiveTab" type="border-card">
|
|
<el-tab-pane label="QC检验文件" name="qcFile">
|
|
<el-form :inline="true" label-position="top" style="margin-bottom: 10px;">
|
|
<el-form-item v-if="detailInformationFlag">
|
|
<el-button type="primary" size="small" @click="addUploadFileModal">上传文件</el-button>
|
|
</el-form-item>
|
|
</el-form>
|
|
<el-table :height="350" :data="fileContentList" border style="width: 100%;">
|
|
<el-table-column v-for="(item,index) in fileColumnList" :key="index" :sortable="item.columnSortable" :prop="item.columnProp" :header-align="item.headerAlign" :show-overflow-tooltip="item.showOverflowTooltip" :align="item.align" :fixed="item.fixed===''?false:item.fixed" :min-width="item.columnWidth" :label="item.columnLabel">
|
|
<template slot-scope="scope">
|
|
<span v-if="!item.columnHidden">{{scope.row[item.columnProp]}}</span>
|
|
<span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px"/></span>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column fixed="right" header-align="center" align="center" width="100" label="操作">
|
|
<template slot-scope="scope">
|
|
<el-link style="cursor: pointer" @click="downloadFile(scope.row)">下载</el-link>
|
|
<el-link style="cursor:pointer" @click="previewFile(scope.row)">预览</el-link>
|
|
<el-link v-if="scope.row.fileType2 !== 'sop'" style="cursor: pointer" @click="deleteFile(scope.row)">删除</el-link>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</el-tab-pane>
|
|
<el-tab-pane label="SOP文件" name="sopFile">
|
|
<el-table :data="sopFileList" border v-loading="sopFileLoading" height="350" style="width: 100%;">
|
|
<el-table-column prop="sopName" header-align="center" align="left" label="文件名称" min-width="200" show-overflow-tooltip></el-table-column>
|
|
<el-table-column prop="fileType" header-align="center" align="center" label="文件类型" width="100"></el-table-column>
|
|
<el-table-column prop="version" header-align="center" align="center" label="版本号" width="80"></el-table-column>
|
|
<el-table-column prop="createdBy" header-align="center" align="center" label="上传人" width="100"></el-table-column>
|
|
<el-table-column prop="creationDate" header-align="center" align="center" label="上传时间" width="150"></el-table-column>
|
|
<el-table-column fixed="right" header-align="center" align="center" width="80" label="操作">
|
|
<template slot-scope="scope">
|
|
<el-link type="primary" @click="previewSopFile(scope.row)">预览</el-link>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</el-tab-pane>
|
|
</el-tabs>
|
|
<el-footer style="height:35px;margin-top: 10px;text-align:center">
|
|
<el-button type="primary" @click="fileFlag=false">关闭</el-button>
|
|
</el-footer>
|
|
</el-dialog>
|
|
|
|
<!-- 子明细信息 -->
|
|
<el-dialog title="子明细信息" :close-on-click-modal="false" v-drag :visible.sync="subDetailFlag" width="572px">
|
|
<el-button type="success" icon="el-icon-plus" size="mini" @click="handleAddBtn(subDetailData)">添加</el-button>
|
|
<el-button type="danger" icon="el-icon-delete" size="mini" @click="handleDeleteBtn(subDetailData)">删除</el-button>
|
|
<el-button type="primary" icon="el-icon-more" size="mini" @click="batchHandleAdd(subDetailData)">批量新增</el-button>
|
|
<div class="rq ">
|
|
<el-table
|
|
:height="400"
|
|
:data="templateTableData"
|
|
border
|
|
:row-class-name="rowClassName"
|
|
@selection-change="handleDetailSelectionChange"
|
|
style="width: 100%;">
|
|
<el-table-column type="selection" align="center" width="50"></el-table-column>
|
|
<el-table-column label="序号" align="center" prop="rowI" width="50"></el-table-column>
|
|
<el-table-column prop="samplingLocation" header-align="center" align="center" :required="true" label="抽样位置A" width="150">
|
|
<template slot-scope="{row}">
|
|
<el-input v-if="templateTableData[row.xh-1].isSubmit === 'Y'" v-model="templateTableData[row.xh-1].samplingLocation" readonly placeholder="请输入抽样位置A"></el-input>
|
|
<el-input v-else :ref="`${row.xh-1}` + `a`" v-model="templateTableData[row.xh-1].samplingLocation" @keyup.enter.native="nextFocus1(row.xh-1)" placeholder="请输入抽样位置A"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="samplingLocationB" header-align="center" align="center" :required="true" label="抽样位置B" width="150">
|
|
<template slot-scope="{row}">
|
|
<el-input v-if="templateTableData[row.xh-1].isSubmit === 'Y'" v-model="templateTableData[row.xh-1].samplingLocationB" readonly placeholder="请输入抽样位置B"></el-input>
|
|
<el-input v-else :ref="`${row.xh-1}` + `b`" v-model="templateTableData[row.xh-1].samplingLocationB" @keyup.enter.native="nextFocus2(row.xh-1)" placeholder="请输入抽样位置B"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="subDetailValue" header-align="center" align="center" :required="true" label="实测值A" width="200">
|
|
<template slot-scope="{row}">
|
|
<el-input v-if="templateTableData[row.xh-1].isSubmit === 'Y'" v-model="templateTableData[row.xh-1].subDetailValue" readonly placeholder="请输入实测值"></el-input>
|
|
<el-input v-else :ref="`${row.xh-1}` + `c`" v-model="templateTableData[row.xh-1].subDetailValue" @keyup.enter.native="nextFocus3(row.xh-1)" placeholder="请输入实测值"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="subDetailValueB" header-align="center" align="center" :required="true" label="实测值B" width="150">
|
|
<template slot-scope="{row}">
|
|
<el-input v-if="templateTableData[row.xh-1].isSubmit === 'Y'" v-model="templateTableData[row.xh-1].subDetailValueB" readonly placeholder="请输入实测值B"></el-input>
|
|
<el-input v-else :ref="`${row.xh-1}` + `d`" v-model="templateTableData[row.xh-1].subDetailValueB" @keyup.enter.native="nextFocus4(row.xh-1)" placeholder="请输入实测值B"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="subDetailValueC" header-align="center" align="center" :required="true" label="实测值C" width="150">
|
|
<template slot-scope="{row}">
|
|
<el-input v-if="templateTableData[row.xh-1].isSubmit === 'Y'" v-model="templateTableData[row.xh-1].subDetailValueC" readonly placeholder="请输入实测值C"></el-input>
|
|
<el-input v-else :ref="`${row.xh-1}` + `e`" v-model="templateTableData[row.xh-1].subDetailValueC" @keyup.enter.native="nextFocus5(row.xh-1)" placeholder="请输入实测值C"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="subDetailValueD" header-align="center" align="center" :required="true" label="实测值D" width="150">
|
|
<template slot-scope="{row}">
|
|
<el-input v-if="templateTableData[row.xh-1].isSubmit === 'Y'" v-model="templateTableData[row.xh-1].subDetailValueD" readonly placeholder="请输入实测值D"></el-input>
|
|
<el-input v-else :ref="`${row.xh-1}` + `f`" v-model="templateTableData[row.xh-1].subDetailValueD" @keyup.enter.native="nextFocus6(row.xh-1)" placeholder="请输入实测值D"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column prop="subDetailValueE" header-align="center" align="center" :required="true" label="实测值E" width="150">
|
|
<template slot-scope="{row}">
|
|
<el-input v-if="templateTableData[row.xh-1].isSubmit === 'Y'" v-model="templateTableData[row.xh-1].subDetailValueE" readonly placeholder="请输入实测值E"></el-input>
|
|
<el-input v-else :ref="`${row.xh-1}` + `g`" v-model="templateTableData[row.xh-1].subDetailValueE" @keyup.enter.native="nextFocus7(row.xh-1)" placeholder="请输入实测值E"></el-input>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
<!-- 分页-->
|
|
<el-pagination
|
|
@size-change="sizeChangeHandle2"
|
|
@current-change="currentChangeHandle2"
|
|
:current-page="pageIndex2"
|
|
:page-sizes="[20, 50, 100, 200, 500]"
|
|
:page-size="pageSize2"
|
|
:total="tableData.length"
|
|
layout="total, sizes, prev, pager, next, jumper">
|
|
</el-pagination>
|
|
</div>
|
|
<el-footer style="height:40px;margin-top: 10px;text-align:center">
|
|
<el-button v-if="detailData.submitFlag !== 'Y'" type="primary" @click="saveSubDetailResult">保存</el-button>
|
|
<el-button type="primary" @click="subDetailFlag = false">关闭</el-button>
|
|
</el-footer>
|
|
</el-dialog>
|
|
|
|
<!-- 批量新增子明细操作-->
|
|
<el-dialog title="批量新增" :close-on-click-modal="false" v-drag :visible.sync="batchHandleAddModalFlag" width="510px">
|
|
<el-form :inline="true" label-position="top">
|
|
<el-form-item :label="'默认抽样位置A'">
|
|
<el-input v-model="batchAddData.samplingLocation" style="width: 150px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="'默认抽样位置B'">
|
|
<el-input v-model="batchAddData.samplingLocationB" style="width: 150px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="'抽样数量'">
|
|
<el-input type="number" v-model="batchAddData.samplingNumber" style="width: 150px"></el-input>
|
|
</el-form-item>
|
|
</el-form>
|
|
<el-footer style="height:40px;margin-top: 10px;text-align:center">
|
|
<el-button type="primary" @click="batchHandleAddModal">保存</el-button>
|
|
<el-button type="primary" @click="batchHandleAddModalFlag = false">关闭</el-button>
|
|
</el-footer>
|
|
</el-dialog>
|
|
|
|
<!-- 机修人员清单 -->
|
|
<el-dialog title="人员清单" :close-on-click-modal="false" v-drag :visible.sync="operatorModelFlag" width="820px">
|
|
<div class="rq">
|
|
<el-form :inline="true" label-position="top" :model="operatorData">
|
|
<el-form-item :label="'所属角色'">
|
|
<el-select v-model="operatorData.roleId" placeholder="请选择" style="width: 120px">
|
|
<el-option
|
|
v-for = "i in roleList"
|
|
:key = "i.roleId"
|
|
:label = "i.roleName"
|
|
:value = "i.roleId">
|
|
</el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item :label="'用户编码'">
|
|
<el-input v-model="operatorData.adminID" clearable style="width: 120px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="'用户姓名'">
|
|
<el-input v-model="operatorData.adminName" clearable style="width: 120px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item :label="' '">
|
|
<el-button type="primary" @click="getOperatorList2">查询</el-button>
|
|
</el-form-item>
|
|
</el-form>
|
|
<el-table
|
|
:height="300"
|
|
:data="operatorList"
|
|
ref="operatorTable"
|
|
@row-click="operatorClickRow"
|
|
@selection-change="selectionChangeHandle2"
|
|
border
|
|
style="width: 100%;">
|
|
<el-table-column
|
|
type="selection"
|
|
header-align="center"
|
|
align="center"
|
|
width="50">
|
|
</el-table-column>
|
|
<el-table-column
|
|
v-for="(item,index) in operatorDetailList" :key="index"
|
|
:sortable="item.columnSortable"
|
|
:prop="item.columnProp"
|
|
:header-align="item.headerAlign"
|
|
:show-overflow-tooltip="item.showOverflowTooltip"
|
|
:align="item.align"
|
|
:fixed="item.fixed==''?false:item.fixed"
|
|
:min-width="item.columnWidth"
|
|
:label="item.columnLabel">
|
|
<template slot-scope="scope">
|
|
<span v-if="!item.columnHidden">{{scope.row[item.columnProp]}}</span>
|
|
<span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px"/></span>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</div>
|
|
<el-footer style="height:40px;margin-top: 20px;text-align:center">
|
|
<el-button type="primary" @click="confirmOperator">确认</el-button>
|
|
<el-button type="primary" @click="operatorModelFlag = false">关闭</el-button>
|
|
</el-footer>
|
|
</el-dialog>
|
|
|
|
<!-- 更改检验方式 -->
|
|
<el-dialog title="更改检验方式" top="25vh" :close-on-click-modal="false" v-drag :visible.sync="changeModalFlag" width="500px">
|
|
<el-form :inline="true" label-position="top" :model="changeData" style="margin-left: 7px;margin-top: -5px;">
|
|
<el-form-item label="检验方式">
|
|
<el-select v-model="changeData.inspectCode" style="width: 210px">
|
|
<el-option label="全检" value="全检"></el-option>
|
|
<el-option label="数量抽检" value="数量抽检"></el-option>
|
|
<el-option label="比例抽检" value="比例抽检"></el-option>
|
|
<el-option label="不固定抽检" value="不固定抽检"></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="抽检数量">
|
|
<el-input class="inlineNumber numInput" v-model="changeData.qtySample" type="number" style="width: 110px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="抽检比例">
|
|
<el-input class="inlineNumber numInput" v-model="changeData.percentSample" type="number" style="width: 110px"></el-input>
|
|
</el-form-item>
|
|
</el-form>
|
|
<el-form :inline="true" label-position="top" :model="changeData" style="margin-left: 7px;margin-top: -5px;">
|
|
<el-form-item>
|
|
<span slot="label" @click="getBaseList(207)"><a herf="#">抽样方案编码</a></span>
|
|
<el-input v-model="changeData.samplingProgrammeNo" style="width: 143px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="抽样方案名称">
|
|
<el-input v-model="changeData.samplingProgrammeDesc" disabled style="width: 300px"></el-input>
|
|
</el-form-item>
|
|
</el-form>
|
|
<el-form :inline="true" label-position="top" :model="changeData" style="margin-left: 7px;margin-top: -5px;">
|
|
<el-form-item>
|
|
<span slot="label" @click="getBaseList(208)"><a herf="#">检验水平编码</a></span>
|
|
<el-input v-model="changeData.samplingLevelNo" style="width: 143px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="检验水平名称">
|
|
<el-input v-model="changeData.samplingLevelDesc" disabled style="width: 300px"></el-input>
|
|
</el-form-item>
|
|
</el-form>
|
|
<el-footer style="height:40px;margin-top: 10px;text-align:center">
|
|
<el-button type="primary" @click="changeInspectionWay">保存</el-button>
|
|
<el-button type="primary" @click="changeModalFlag = false">关闭</el-button>
|
|
</el-footer>
|
|
</el-dialog>
|
|
|
|
<Chooselist ref="baseList" @getBaseData="getBaseData"></Chooselist>
|
|
|
|
<!-- 上传文件的modal -->
|
|
<qcFAIUploadFile ref="qcFAIUploadFile" @refreshPageTables="()=>{this.getFileContentData(this.detailData)}" v-drag></qcFAIUploadFile>
|
|
|
|
<!-- 上传文件的modal -->
|
|
<comQcItemImageUploadFile ref="comQcItemImageUploadFile" @refreshPageTables2="getInspectionFormData" v-drag></comQcItemImageUploadFile>
|
|
|
|
<!-- 子明细导入 -->
|
|
<subDetailUpload @changeEvent="changeMyString" ref="subDetailUpload" @refreshPageTables="getInspectionFormData" v-drag></subDetailUpload>
|
|
|
|
<!-- 项目操作对话框 -->
|
|
<el-dialog title="检验项目操作" @close="refreshInspectionDetailList" :close-on-click-modal="false" v-drag :visible.sync="itemOperationDialogFlag" width="1200px" custom-class="item-operation-dialog">
|
|
<div class="search-container">
|
|
<el-form :inline="true" size="small">
|
|
<el-form-item label="项目编码">
|
|
<el-input v-model="itemOperationQuery.itemNo" placeholder="请输入项目编码" clearable prefix-icon="el-icon-search" style="width: 160px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="项目名称">
|
|
<el-input v-model="itemOperationQuery.itemDesc" placeholder="请输入项目名称" clearable prefix-icon="el-icon-search" style="width: 200px"></el-input>
|
|
</el-form-item>
|
|
<el-button type="primary" icon="el-icon-search" size="small" @click="searchOQCItems">查询</el-button>
|
|
<el-button icon="el-icon-refresh" size="small" @click="resetItemQuery">重置</el-button>
|
|
</el-form>
|
|
</div>
|
|
<div class="item-operation-content">
|
|
<div class="item-panel available-panel">
|
|
<div class="panel-header">
|
|
<i class="el-icon-menu"></i>
|
|
<span class="panel-title">可选项目列表</span>
|
|
<span class="item-count">{{ availableItemList.length }}</span>
|
|
</div>
|
|
<el-table ref="availableItemTable" :data="availableItemList" @row-click="availableItemClickRow" @selection-change="availableItemSelectionChange" highlight-current-row class="operation-table" height="400" border>
|
|
<el-table-column type="selection" width="45" align="center"></el-table-column>
|
|
<el-table-column prop="itemNo" label="项目编码" min-width="120"></el-table-column>
|
|
<el-table-column prop="itemDesc" label="项目名称" min-width="180" show-overflow-tooltip></el-table-column>
|
|
</el-table>
|
|
</div>
|
|
<div class="operation-buttons">
|
|
<el-tooltip content="添加选中项目" placement="left">
|
|
<el-button type="primary" icon="el-icon-d-arrow-right" circle @click="addInspectionItems" :disabled="!availableItemSelections || availableItemSelections.length === 0"></el-button>
|
|
</el-tooltip>
|
|
<el-tooltip content="移除选中项目" placement="right">
|
|
<el-button type="danger" icon="el-icon-d-arrow-left" circle @click="deleteInspectionItems" :disabled="!selectedItemSelections || selectedItemSelections.length === 0"></el-button>
|
|
</el-tooltip>
|
|
</div>
|
|
<div class="item-panel selected-panel">
|
|
<div class="panel-header">
|
|
<i class="el-icon-tickets"></i>
|
|
<span class="panel-title">已有项目列表</span>
|
|
<span class="item-count">{{ selectedItemList.length }}</span>
|
|
</div>
|
|
<el-table ref="selectedItemTable" :data="selectedItemList" @row-click="selectedItemClickRow" @selection-change="selectedItemSelectionChange" highlight-current-row class="operation-table" height="400" border>
|
|
<el-table-column type="selection" width="45" align="center"></el-table-column>
|
|
<el-table-column prop="itemNo" label="项目编码" min-width="120"></el-table-column>
|
|
<el-table-column prop="itemDesc" label="项目名称" min-width="180" show-overflow-tooltip></el-table-column>
|
|
</el-table>
|
|
</div>
|
|
</div>
|
|
<div slot="footer" class="dialog-footer">
|
|
<el-button @click="itemOperationDialogFlag = false" size="small" style="width: 80px;">关闭</el-button>
|
|
</div>
|
|
</el-dialog>
|
|
|
|
<!-- 模板导入对话框 -->
|
|
<el-dialog title="模板导入" :close-on-click-modal="false" v-drag :visible.sync="templateImportDialogFlag" width="900px" custom-class="template-import-dialog">
|
|
<div class="search-container">
|
|
<el-form :inline="true" size="small">
|
|
<el-form-item label="模板编码">
|
|
<el-input v-model="templateQuery.templateId" placeholder="请输入模板编码" clearable prefix-icon="el-icon-search" style="width: 160px"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="模板名称">
|
|
<el-input v-model="templateQuery.templateDesc" placeholder="请输入模板名称" clearable prefix-icon="el-icon-search" style="width: 200px"></el-input>
|
|
</el-form-item>
|
|
<el-button type="primary" icon="el-icon-search" size="small" @click="searchOQCTemplates">查询</el-button>
|
|
<el-button icon="el-icon-refresh-left" size="small" @click="resetTemplateQuery">重置</el-button>
|
|
</el-form>
|
|
</div>
|
|
<div class="template-list-container">
|
|
<div class="panel-header">
|
|
<i class="el-icon-s-grid"></i>
|
|
<span class="panel-title">OQC检验模板</span>
|
|
<span class="item-count">({{ templateList.length }})</span>
|
|
</div>
|
|
<el-table ref="templateTable" :data="templateList" @row-click="templateClickRow" @selection-change="templateSelectionChange" highlight-current-row class="template-table" height="450" :header-cell-style="{background: '#f5f7fa', color: '#606266', fontWeight: '500'}">
|
|
<el-table-column type="selection" width="50" align="center"></el-table-column>
|
|
<el-table-column prop="templateId" label="模板编码" align="center" width="120"></el-table-column>
|
|
<el-table-column prop="templateName" label="模板名称" align="left" min-width="200" show-overflow-tooltip></el-table-column>
|
|
<el-table-column prop="itemCount" label="项目数量" align="center" width="100"></el-table-column>
|
|
</el-table>
|
|
</div>
|
|
<div slot="footer" class="dialog-footer">
|
|
<el-button type="primary" icon="el-icon-download" @click="confirmImportTemplate" :disabled="!templateSelections || templateSelections.length === 0" :loading="importLoading" size="small">导入选中模板</el-button>
|
|
<el-button @click="templateImportDialogFlag = false" size="small" style="width: 80px;">关闭</el-button>
|
|
</div>
|
|
</el-dialog>
|
|
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import {
|
|
qcOQCInspectionSearch, // OQC检验记录查询
|
|
fqasDetailSearch, // FQAS检验记录查询
|
|
selectFQASSubDetailedRecord, // 查询子明细记录
|
|
saveFQASDetailedRecord, // 新增明细信息
|
|
checkFQASIsSubmit, // 检查是否已提交
|
|
saveFQASSubDetailed, // 新增子明细信息
|
|
saveFQASSubmitResult, // 审核
|
|
fqasRecordDelete, // 删除检验记录
|
|
disposalMeasuresSearch, // 获取处置措施列表
|
|
fqasRecordOverLoad, // 重载检验单
|
|
getSiteAndBuByUserName,
|
|
actionFQASInspection, // 开始检验
|
|
dataAcquisition, // 数据采集
|
|
changeInspectionWay, // 更改检验方式
|
|
getFileContentList2,
|
|
downLoadObjectFile,
|
|
deleteObjectFile,
|
|
getUserRoleList,
|
|
getOperatorList,
|
|
// OQC检验项目操作和模板导入
|
|
getOQCItemList,
|
|
addOQCItemDetails,
|
|
deleteOQCItemDetails,
|
|
getOQCTemplateList,
|
|
importOQCTemplateItems,
|
|
searchQcSopFileList,
|
|
downloadSopFile
|
|
} from "@/api/qc/qc.js"
|
|
import {getTableDefaultListLanguage, getTableUserListLanguage} from "@/api/table.js"
|
|
import Chooselist from '@/views/modules/common/Chooselist_eam'
|
|
import {userFavoriteList, saveUserFavorite, removeUserFavorite} from '@/api/userFavorite.js'
|
|
import qcFAIUploadFile from "./qc_FAI_upload_file"
|
|
import comQcItemImageUploadFile from "./com_qc_itemImage_upload_file"
|
|
import subDetailUpload from "./sub_detail_upload"
|
|
export default {
|
|
components: {
|
|
Chooselist,
|
|
qcFAIUploadFile,
|
|
comQcItemImageUploadFile,
|
|
subDetailUpload
|
|
},
|
|
computed: {
|
|
templateTableData () {
|
|
let start = (this.pageIndex2 - 1) * this.pageSize2
|
|
let end = start + this.pageSize2
|
|
if (end > this.tableData.length){
|
|
end = this.tableData.length
|
|
}
|
|
return this.tableData.slice(start,end)
|
|
}
|
|
},
|
|
watch: {
|
|
detailData: {
|
|
deep: true,
|
|
handler: function (newV, oldV) {
|
|
this.detailData.notPassQty = this.detailData.samplingQty - this.detailData.passQty
|
|
}
|
|
},
|
|
detailList: {
|
|
deep: true,
|
|
handler: function (newV, oldV) {
|
|
let num = 0
|
|
for (let i = 0; i < this.detailList.length; i++) {
|
|
if (this.detailList[i].itemResult === 'N') {
|
|
num++
|
|
}
|
|
}
|
|
this.detailData.unqualifiedQty = num
|
|
}
|
|
},
|
|
},
|
|
data () {
|
|
return {
|
|
searchExpanded: false, // 搜索条件展开状态,默认收起
|
|
loadFlag: false,
|
|
// 是否收藏
|
|
favorite: false,
|
|
// 导出 start
|
|
exportData: [],
|
|
transferLoadFlag: false,
|
|
exportName: "FQAS检验录入" + this.dayjs().format('YYYYMMDDHHmmss'),
|
|
exportHeader: ["FQAS检验录入"],
|
|
exportFooter: [],
|
|
exportList: [],
|
|
// 导出 end
|
|
submitData: {
|
|
site: '',
|
|
inspectionNo: '',
|
|
isQualified: '',
|
|
isQualifiedChinese: '',
|
|
submitList: [],
|
|
updateBy: this.$store.state.user.name,
|
|
},
|
|
tagNo:'',
|
|
searchData: {
|
|
site: '',
|
|
userName: this.$store.state.user.name,
|
|
inspectionNo: '',
|
|
inspectionTypeNo:'109',
|
|
isQualified: '',
|
|
buDesc: '',
|
|
startDate: '',
|
|
endDate: '',
|
|
startDate2: '',
|
|
endDate2: '',
|
|
partNo:'',
|
|
partDesc:'',
|
|
state: '',
|
|
inspectionResult: '',
|
|
disposalMeasures: '',
|
|
inspectorName: '',
|
|
page: 1,
|
|
limit: 10,
|
|
states: ['未开始','待检验'],
|
|
customerNo: '',
|
|
customerName: '',
|
|
poOrderNo: ''
|
|
},
|
|
pageIndex: 1,
|
|
pageSize: 200,
|
|
totalPage: 0,
|
|
pageIndex2: 1,
|
|
pageSize2: 20,
|
|
totalPage2: 0,
|
|
height: 200,
|
|
dataList: [],
|
|
dataListSelections: [],
|
|
submitFlag: false,
|
|
modalData: {
|
|
flag:'',
|
|
functionType:'',
|
|
site: '',
|
|
bu: '',
|
|
inspectionNo:'',
|
|
workOrderNumber: '',
|
|
workOrderQuantity: '',
|
|
reelNumber: '',
|
|
partNo: '',
|
|
rollingQuantity: '',
|
|
sampleQuantity: '',
|
|
detailCodeNo:'',
|
|
detailCodeDesc:'',
|
|
inspectionTypeNo:'109',
|
|
inspectionTypeName:'OQC',
|
|
inspectorNo:'',
|
|
inspectorName:'',
|
|
isQualified:'',
|
|
isQualifiedChinese:''
|
|
},
|
|
// 展示列集
|
|
// columnList1: [],
|
|
columnList1: [
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1BuDesc',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'buDesc',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: 'BU',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1InspectionNo',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'inspectionNo',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '检验单号',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 120,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1InspectionResult',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'inspectionResult',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '检验结论',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1TaskDate',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'taskDate',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '送检日期',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 130,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1InspectionCycle',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'inspectionCycle',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: '检验周期(h)',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1RollNo',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'rollNo',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '标签条码',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 120,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1PartNo',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'partNo',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '物料编码',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 120,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1PartDesc',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'partDesc',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '物料名称',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 200,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1Spec',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'spec',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '规格型号',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 120,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1Umid',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'umName',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '计量单位',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1RollQty',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'rollQty',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: '发货数量',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1RollCount',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'rollCount',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: '送检数量',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1SamplingQty',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'samplingQty',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: '抽样数量',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1PoOrderNo',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'poOrderNo',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '关联单号',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1PoItemNo',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'poItemNo',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '关联单行号',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1CustomerNo',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'customerNo',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '客户编码',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1CustomerName',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'customerName',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '客户名称',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 150,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1InspectionRemark',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'inspectionRemark',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '质检备注',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 200,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1DisposalMeasures',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'disposalMeasures',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '处置措施',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 120,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1DisposalRemark',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'disposalRemark',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '处置说明',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 200,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1ActionDate',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'actionDate',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '开始检验时间',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 170,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1InspectorDate',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'inspectorDate',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '检验时间',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 170,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1CreateBy',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'createBy',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '送检员',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table1InspectorName',
|
|
tableId: "301017Table1",
|
|
tableName: "OQC检验记录表",
|
|
columnProp: 'inspectorName',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '质检员',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
],
|
|
detailColumnList: [
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2ItemNo',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'itemNo',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '检验项目编码',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 120,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2ItemDesc',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'itemDesc',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '检验项目',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 150,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2SamplingLevelDesc',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'samplingLevelDesc',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '检验水平',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 150,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2SamplingProgrammeDesc',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'samplingProgrammeDesc',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '检验方案',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 150,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2MethodName',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'methodName',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '检验方法',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 150,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2MethodRemark',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'methodRemark',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '检验方法说明',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 200,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2ObjectDesc',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'objectDesc',
|
|
headerAlign: "center",
|
|
align: "left",
|
|
columnLabel: '检测仪器',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 150,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2Aql',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'aql',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: 'AQL',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2Ac',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'ac',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: 'AC',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2Re',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 're',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: 'RE',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2DefaultValue',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'defaultValue',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '标准值',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2MaxValue',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'maxValue',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: '最大值',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2MinValue',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'minValue',
|
|
headerAlign: "center",
|
|
align: "right",
|
|
columnLabel: '最小值',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
{
|
|
userId: this.$store.state.user.name,
|
|
functionId: 301017,
|
|
serialNumber: '301017Table2ValueType',
|
|
tableId: "301017Table2",
|
|
tableName: "检验单明细表",
|
|
columnProp: 'valueType',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '检测值类型',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
columnWidth: 100,
|
|
},
|
|
],
|
|
fileColumnList: [
|
|
{
|
|
columnProp: 'fileName',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '文件名称',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
},
|
|
{
|
|
columnProp: 'createdBy',
|
|
headerAlign: "center",
|
|
align: 'center',
|
|
columnLabel: '上传人',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: true,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: false
|
|
},
|
|
{
|
|
columnProp: 'createDate',
|
|
headerAlign: "center",
|
|
align: 'center',
|
|
columnLabel: '上传时间',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: true,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: false
|
|
},
|
|
{
|
|
columnProp: 'orderRef3',
|
|
headerAlign: "center",
|
|
align: 'center',
|
|
columnLabel: '备注',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: true,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: false
|
|
},
|
|
],
|
|
detailData: {
|
|
site: '',
|
|
buNo: '',
|
|
inspectionNo: '',
|
|
partNo: '',
|
|
partDesc: '',
|
|
rollQty: '',
|
|
samplingQty: '',
|
|
unqualifiedQty: 0,
|
|
unqualifiedQuantity: '',
|
|
disposalMeasures: '',
|
|
disposalRemark: '',
|
|
inspectionResult: '',
|
|
inspectorNo: '',
|
|
inspectionRemark: '',
|
|
submitFlag: '',
|
|
umId: '',
|
|
umName: '',
|
|
rollCount: '',
|
|
operator: '',
|
|
operatorName: '',
|
|
responsiblePerson: '',
|
|
responsiblePersonName: '',
|
|
passQty: '',
|
|
notPassQty: '',
|
|
spec: '',
|
|
state: ''
|
|
},
|
|
detailInformationFlag: false,
|
|
detailList: [],
|
|
saveInformationData: {
|
|
site: '',
|
|
buNo: '',
|
|
inspectionNo:'',
|
|
disposalMeasures: '',
|
|
disposalRemark: '',
|
|
inspectorNo: '',
|
|
inspectionRemark: '',
|
|
itemList:[],
|
|
unqualifiedQty: '',
|
|
rollCount: '',
|
|
samplingQty: '',
|
|
partNo: '',
|
|
partDesc: '',
|
|
operator: '',
|
|
operatorName: '',
|
|
responsiblePerson: '',
|
|
responsiblePersonName: '',
|
|
subDetailList: [],
|
|
passQty: '',
|
|
notPassQty: ''
|
|
},
|
|
// 子明细数据对象
|
|
tableData: [],
|
|
checkedDetail: [],
|
|
subDetailFlag: false,
|
|
subDetailData: {
|
|
site: '',
|
|
buNo: '',
|
|
inspectionNo: '',
|
|
itemNo: '',
|
|
itemDesc: '',
|
|
defaultValue: '',
|
|
maxValue: '',
|
|
minValue: '',
|
|
valueTypeDb: '',
|
|
subDetailValues:[]
|
|
},
|
|
options: [],
|
|
fileFlag: false,
|
|
fileContentList: [],
|
|
fileActiveTab: 'qcFile',
|
|
sopFileList: [],
|
|
sopFileLoading: false,
|
|
currentFileRow: null,
|
|
FQASSelections: [],
|
|
batchHandleAddModalFlag: false,
|
|
batchAddData: {
|
|
samplingLocation: '',
|
|
samplingLocationB: '',
|
|
samplingNumber: ''
|
|
},
|
|
disposalMeasuresOptions: [],
|
|
userBuList: [],
|
|
authSearch: false,
|
|
authCheck: false,
|
|
authOverLoad: false,
|
|
authDelete: false,
|
|
authDetail: false,
|
|
authFile: false,
|
|
authChange: false,
|
|
menuId: this.$route.meta.menuId,
|
|
roleList: [],
|
|
operatorList: [],
|
|
operatorData: {
|
|
flag: '',
|
|
site: '',
|
|
bu: '',
|
|
adminID: '',
|
|
adminName: '',
|
|
roleName: '',
|
|
roleId: '',
|
|
},
|
|
operatorModelFlag: false,
|
|
dataListSelections2: [],
|
|
operatorDetailList: [
|
|
{
|
|
columnProp: 'adminID',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '用户账号',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
},
|
|
{
|
|
columnProp: 'adminName',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '用户名称',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
},
|
|
{
|
|
columnProp: 'email',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '邮箱',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
},
|
|
{
|
|
columnProp: 'phone',
|
|
headerAlign: "center",
|
|
align: "center",
|
|
columnLabel: '手机号',
|
|
columnHidden: false,
|
|
columnImage: false,
|
|
columnSortable: false,
|
|
sortLv: 0,
|
|
status: true,
|
|
fixed: '',
|
|
},
|
|
],
|
|
acquisitionList: [],
|
|
fileData: {
|
|
site: '',
|
|
buNo: '',
|
|
inspectionNo: '',
|
|
partNo: '',
|
|
inspectionTypeNo: ''
|
|
},
|
|
currentRow: {},
|
|
currentDetailRow: {},
|
|
changeData: {
|
|
site: '',
|
|
buNo: '',
|
|
inspectionNo: '',
|
|
rollCount: '',
|
|
inspectCode: '',
|
|
qtySample: '',
|
|
percentSample: '',
|
|
samplingProgrammeNo: '',
|
|
samplingProgrammeDesc: '',
|
|
samplingLevelNo: '',
|
|
samplingLevelDesc: '',
|
|
receiptNo: '',
|
|
receiptItemNo: '',
|
|
inspectionTypeNo: ''
|
|
},
|
|
changeModalFlag: false,
|
|
overLoading: false,
|
|
// OQC项目操作相关
|
|
itemOperationDialogFlag: false,
|
|
itemOperationQuery: {
|
|
itemNo: '',
|
|
itemDesc: '',
|
|
},
|
|
availableItemList: [],
|
|
selectedItemList: [],
|
|
availableItemSelections: [],
|
|
selectedItemSelections: [],
|
|
// OQC模板导入相关
|
|
templateImportDialogFlag: false,
|
|
templateQuery: {
|
|
templateId: '',
|
|
templateDesc: '',
|
|
},
|
|
templateList: [],
|
|
templateSelections: [],
|
|
importLoading: false
|
|
}
|
|
},
|
|
|
|
mounted () {
|
|
this.$nextTick(() => {
|
|
this.height = window.innerHeight - 250
|
|
})
|
|
},
|
|
|
|
updated() {
|
|
this.$nextTick(()=>{
|
|
this.$refs.OQCTable.doLayout()
|
|
})
|
|
},
|
|
|
|
created () {
|
|
// 按钮控制
|
|
this.getButtonAuthData()
|
|
// 获取用户的 site 和 bu
|
|
this.getSiteAndBuByUserName()
|
|
this.favoriteIsOk()
|
|
this.disposalMeasuresSearch()
|
|
// 动态列
|
|
this.getTableUserColumn(this.$route.meta.menuId+'table1',1)
|
|
this.getTableUserColumn(this.$route.meta.menuId+'table2',2)
|
|
if (!this.authSearch) {
|
|
// 获取数据列表
|
|
this.getDataList()
|
|
}
|
|
// 获取用户角色
|
|
this.getUserRoleList()
|
|
},
|
|
|
|
methods: {
|
|
// 切换搜索条件展开/收起
|
|
toggleSearchExpand() {
|
|
this.searchExpanded = !this.searchExpanded;
|
|
},
|
|
// 重置搜索条件
|
|
resetSearch() {
|
|
this.searchData = {
|
|
site: '',
|
|
userName: this.$store.state.user.name,
|
|
inspectionNo: '',
|
|
inspectionTypeNo: '109',
|
|
isQualified: '',
|
|
buDesc: '',
|
|
startDate: '',
|
|
endDate: '',
|
|
startDate2: '',
|
|
endDate2: '',
|
|
partNo: '',
|
|
partDesc: '',
|
|
inspectorName: '',
|
|
customerNo: '',
|
|
customerName: '',
|
|
inspectionResult: '',
|
|
disposalMeasures: '',
|
|
states: []
|
|
};
|
|
this.getDataList();
|
|
},
|
|
// 列表数据总结
|
|
getSummaries (param) {
|
|
const { columns, data } = param
|
|
const sums = []
|
|
columns.forEach((column, index) => {
|
|
if (index === 0) {
|
|
sums[index] = '总计'
|
|
return
|
|
}
|
|
if (column.property !== 'rollQty' && column.property !== 'rollCount') {
|
|
sums[index] = ''
|
|
return
|
|
}
|
|
const values = data.map(item => Number(item[column.property]))
|
|
if (!values.every(value => isNaN(value))) {
|
|
sums[index] = values.reduce((prev, curr) => {
|
|
const value = Number(curr)
|
|
if (!isNaN(value)) {
|
|
return prev + curr
|
|
} else {
|
|
return prev
|
|
}
|
|
}, 0)
|
|
} else {
|
|
sums[index] = ''
|
|
}
|
|
})
|
|
return sums
|
|
},
|
|
|
|
// 检验结论改变事件
|
|
resultChange () {
|
|
if (this.detailData.inspectionResult === '不合格') {
|
|
this.detailData.passQty = 0
|
|
}
|
|
},
|
|
// 数据采集
|
|
dataAcquisition () {
|
|
this.loadFlag = true
|
|
let tempDate = {
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
inspectionNo: this.detailData.inspectionNo,
|
|
flag: 'iqc'
|
|
}
|
|
dataAcquisition(tempDate).then(({data}) => {
|
|
if (data.code === 0) {
|
|
// this.acquisitionList = data.rows
|
|
this.changeMyString(data.rows)
|
|
this.$message({
|
|
message: '数据采集成功',
|
|
type: 'success',
|
|
duration: 1500
|
|
})
|
|
} else {
|
|
this.$message({
|
|
message: data.msg,
|
|
type: 'warning',
|
|
duration: 1500
|
|
})
|
|
}
|
|
this.loadFlag = false
|
|
})
|
|
},
|
|
|
|
// 获取用户角色
|
|
getUserRoleList () {
|
|
getUserRoleList().then(({data}) => {
|
|
if (data.code === 0) {
|
|
this.roleList = data.rows
|
|
} else {
|
|
this.roleList = []
|
|
}
|
|
})
|
|
},
|
|
|
|
// 获取协同人员列表
|
|
getOperatorList () {
|
|
this.operatorData.flag = '1'
|
|
this.operatorData.bu = this.detailData.site + '_' + this.detailData.buNo
|
|
if (this.roleList.length > 0) {
|
|
let filterList = this.roleList.filter(item => item.roleName === '机修人员')
|
|
if (filterList.length > 0) {
|
|
this.operatorData.roleId = filterList[0].roleId
|
|
} else {
|
|
this.operatorData.roleId = this.roleList[0].roleId
|
|
}
|
|
} else {
|
|
this.operatorData.roleId = ''
|
|
}
|
|
// 先清空缓存选中
|
|
this.$nextTick(() => this.$refs.operatorTable.clearSelection())
|
|
// 拿到选中的人员编号
|
|
let tempDataList = (this.detailData.operator == null ? '' : this.detailData.operator).split(';')
|
|
getOperatorList(this.operatorData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.operatorList = data.rows
|
|
this.operatorList.forEach(val => {
|
|
// 回显选中
|
|
if (tempDataList.includes(val.adminID)) {
|
|
this.$nextTick(() => this.$refs.operatorTable.toggleRowSelection(val, true))
|
|
}
|
|
})
|
|
this.operatorModelFlag = true
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
},
|
|
|
|
// 获取责任人员列表
|
|
getResponsiblePersonList () {
|
|
this.operatorData.flag = '2'
|
|
this.operatorData.bu = this.detailData.site + '_' + this.detailData.buNo
|
|
if (this.roleList.length > 0) {
|
|
let filterList = this.roleList.filter(item => item.roleName === '系统管理员')
|
|
if (filterList.length > 0) {
|
|
this.operatorData.roleId = filterList[0].roleId
|
|
} else {
|
|
this.operatorData.roleId = this.roleList[0].roleId
|
|
}
|
|
} else {
|
|
this.operatorData.roleId = ''
|
|
}
|
|
// 先清空缓存选中
|
|
this.$nextTick(() => this.$refs.operatorTable.clearSelection())
|
|
// 拿到选中的人员编号
|
|
let tempDataList = (this.detailData.responsiblePerson == null ? '' : this.detailData.responsiblePerson).split(';')
|
|
getOperatorList(this.operatorData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.operatorList = data.rows
|
|
this.operatorList.forEach(val => {
|
|
// 回显选中
|
|
if (tempDataList.includes(val.adminID)) {
|
|
this.$nextTick(() => this.$refs.operatorTable.toggleRowSelection(val, true))
|
|
}
|
|
})
|
|
this.operatorModelFlag = true
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
},
|
|
|
|
// 查询机修人员列表
|
|
getOperatorList2 () {
|
|
if (this.operatorData.flag === '1') {
|
|
// 拿到选中的人员编号
|
|
let tempDataList = (this.detailData.operator == null ? '' : this.detailData.operator).split(';')
|
|
getOperatorList(this.operatorData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.operatorList = data.rows
|
|
this.operatorList.forEach(val => {
|
|
// 回显选中的部门
|
|
if (tempDataList.includes(val.adminID)) {
|
|
this.$nextTick(() => this.$refs.operatorTable.toggleRowSelection(val, true))
|
|
}
|
|
})
|
|
} else {
|
|
this.operatorList = []
|
|
}
|
|
})
|
|
} else {
|
|
// 拿到选中的人员编号
|
|
let tempDataList = (this.detailData.responsiblePerson == null ? '' : this.detailData.responsiblePerson).split(';')
|
|
getOperatorList(this.operatorData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.operatorList = data.rows
|
|
this.operatorList.forEach(val => {
|
|
// 回显选中的部门
|
|
if (tempDataList.includes(val.adminID)) {
|
|
this.$nextTick(() => this.$refs.operatorTable.toggleRowSelection(val, true))
|
|
}
|
|
})
|
|
} else {
|
|
this.operatorList = []
|
|
}
|
|
})
|
|
}
|
|
},
|
|
|
|
// 点击行选中复选框
|
|
operatorClickRow (row) {
|
|
this.$refs.operatorTable.toggleRowSelection(row)
|
|
},
|
|
|
|
// 多选
|
|
selectionChangeHandle2 (val) {
|
|
this.dataListSelections2 = val
|
|
},
|
|
|
|
// 确认多选协同人员
|
|
confirmOperator () {
|
|
if (this.dataListSelections2.length === 0) {
|
|
this.$message.warning('请勾选人员!')
|
|
return
|
|
}
|
|
if (this.operatorData.flag === '1') {
|
|
for (let i = 0; i < this.dataListSelections2.length; i++) {
|
|
if (!this.detailData.operator.split(';').includes(this.dataListSelections2[i].adminID)) {
|
|
this.detailData.operatorName = this.detailData.operatorName + ";" + this.dataListSelections2[i].adminName
|
|
this.detailData.operator = this.detailData.operator + ";" + this.dataListSelections2[i].adminID
|
|
}
|
|
}
|
|
if (this.detailData.operator.charAt(0) === ';') {
|
|
this.detailData.operator = this.detailData.operator.substring(1)
|
|
this.detailData.operatorName = this.detailData.operatorName.substring(1)
|
|
}
|
|
} else {
|
|
for (let i = 0; i < this.dataListSelections2.length; i++) {
|
|
if (!this.detailData.responsiblePerson.split(';').includes(this.dataListSelections2[i].adminID)) {
|
|
this.detailData.responsiblePersonName = this.detailData.responsiblePersonName + ";" + this.dataListSelections2[i].adminName
|
|
this.detailData.responsiblePerson = this.detailData.responsiblePerson + ";" + this.dataListSelections2[i].adminID
|
|
}
|
|
}
|
|
if (this.detailData.responsiblePerson.charAt(0) === ';') {
|
|
this.detailData.responsiblePerson = this.detailData.responsiblePerson.substring(1)
|
|
this.detailData.responsiblePersonName = this.detailData.responsiblePersonName.substring(1)
|
|
}
|
|
}
|
|
this.operatorData = {
|
|
flag: '',
|
|
site: '',
|
|
bu: '',
|
|
adminID: '',
|
|
adminName: '',
|
|
roleName: '',
|
|
roleId: '',
|
|
}
|
|
this.operatorModelFlag = false
|
|
},
|
|
|
|
|
|
// // 实测值内容改变事件
|
|
// changeValue (row) {
|
|
// if (row.minValue == null && row.maxValue != null) {
|
|
// if (row.numberValue > row.maxValue) {
|
|
// row.itemResult = 'N'
|
|
// } else {
|
|
// row.itemResult = 'Y'
|
|
// }
|
|
// } else if (row.maxValue == null && row.minValue != null) {
|
|
// if (row.numberValue < row.minValue) {
|
|
// row.itemResult = 'N'
|
|
// } else {
|
|
// row.itemResult = 'Y'
|
|
// }
|
|
// } else if (row.minValue != null && row.maxValue != null) {
|
|
// if (row.numberValue < row.minValue || row.numberValue > row.maxValue) {
|
|
// row.itemResult = 'N'
|
|
// } else {
|
|
// row.itemResult = 'Y'
|
|
// }
|
|
// }
|
|
// },
|
|
|
|
// 获取用户的bu
|
|
getSiteAndBuByUserName () {
|
|
let tempData = {
|
|
username: this.$store.state.user.name,
|
|
}
|
|
getSiteAndBuByUserName(tempData).then(({data}) => {
|
|
if (data.code === 0) {
|
|
this.userBuList = data.rows
|
|
}
|
|
})
|
|
},
|
|
|
|
// ======= 正则校验 =======
|
|
handleInput (value, type) {
|
|
// 大于等于0,且只能输入4位小数
|
|
let val = value.replace(/^\D*([0-9]\d*\.?\d{0,4})?.*$/,'$1')
|
|
if (val === null || val === undefined || val === '') {
|
|
val = 0
|
|
}
|
|
if (type === 1) {
|
|
this.detailData.unqualifiedQty = val
|
|
} else if (type === 2) {
|
|
this.detailData.passQty = val
|
|
}
|
|
},
|
|
|
|
// 子明细导入
|
|
subDetailUpload () {
|
|
let currentData = {
|
|
flag: 'FQAS',
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
inspectionNo: this.detailData.inspectionNo
|
|
}
|
|
//打开组件 去做新增业务
|
|
this.$nextTick(() => {
|
|
this.$refs.subDetailUpload.init(currentData)
|
|
})
|
|
},
|
|
|
|
// 获取处置措施列表
|
|
disposalMeasuresSearch () {
|
|
let tempData = {
|
|
inspectionTypeNo: '109'
|
|
}
|
|
disposalMeasuresSearch(tempData).then(({data}) => {
|
|
if (data.code === 0) {
|
|
this.disposalMeasuresOptions = data.rows
|
|
}
|
|
})
|
|
},
|
|
|
|
// 单机选中
|
|
FQASClickRow (row) {
|
|
this.currentRow = JSON.parse(JSON.stringify(row))
|
|
},
|
|
|
|
// 复选
|
|
selectionFQAS (val) {
|
|
this.FQASSelections = val
|
|
},
|
|
|
|
// 单机选中
|
|
OQCDetailClickRow (row) {
|
|
this.currentDetailRow = JSON.parse(JSON.stringify(row))
|
|
},
|
|
|
|
rowDetailStyle ({row}) {
|
|
if (this.currentDetailRow.itemNo === row.itemNo) {
|
|
return { 'background-color': '#50DCDC', cursor: 'pointer' };
|
|
}
|
|
},
|
|
|
|
// 刷新派设备文档的列表
|
|
getFileContentData (row) {
|
|
this.currentFileRow = row
|
|
this.fileActiveTab = 'qcFile'
|
|
this.fileData = {
|
|
site: row.site,
|
|
buNo: row.buNo,
|
|
inspectionNo: row.inspectionNo,
|
|
partNo: row.partNo,
|
|
inspectionTypeNo: '109'
|
|
}
|
|
getFileContentList2(this.fileData).then(({data}) => {
|
|
if (data && data.code == 200) {
|
|
this.fileContentList = data.rows
|
|
} else {
|
|
this.fileContentList = []
|
|
}
|
|
})
|
|
this.getSopFileList(row)
|
|
this.fileFlag = true
|
|
},
|
|
|
|
// 获取SOP文件列表(OQC传site、partNo和orderNo)
|
|
getSopFileList(row) {
|
|
this.sopFileLoading = true
|
|
this.sopFileList = []
|
|
searchQcSopFileList({
|
|
site: row.site,
|
|
partNo: row.partNo || '',
|
|
orderNo: row.orderNo || ''
|
|
}).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.sopFileList = data.rows || []
|
|
} else {
|
|
this.sopFileList = []
|
|
}
|
|
this.sopFileLoading = false
|
|
}).catch(() => {
|
|
this.sopFileList = []
|
|
this.sopFileLoading = false
|
|
})
|
|
},
|
|
|
|
previewSopFile(row) {
|
|
if (!row.sopUrl) { this.$message.warning('该文件暂无预览路径'); return }
|
|
const fileName = row.sopName || row.sopUrl
|
|
let fileSuffix = fileName.includes('.') ? fileName.substring(fileName.lastIndexOf('.') + 1).toLowerCase() : ''
|
|
const officeTypes = ['doc', 'docx', 'ppt', 'pptx', 'xls', 'xlsx']
|
|
if (officeTypes.includes(fileSuffix)) { this.$message.warning(`暂不支持在线预览${fileSuffix.toUpperCase()}文件`); return }
|
|
let mimeType = 'application/octet-stream'
|
|
if (['jpg', 'jpeg', 'png', 'gif', 'bmp'].includes(fileSuffix)) { mimeType = 'image/' + fileSuffix }
|
|
else if (['mp4', 'avi', 'mov', 'wmv', 'flv'].includes(fileSuffix)) { mimeType = 'video/' + fileSuffix }
|
|
else if (fileSuffix === 'pdf') { mimeType = 'application/pdf' }
|
|
else if (fileSuffix === 'txt') { mimeType = 'text/plain' }
|
|
downloadSopFile(row.sopUrl).then(({ data }) => {
|
|
const blob = new Blob([data], { type: mimeType })
|
|
window.open(URL.createObjectURL(blob), '_blank')
|
|
}).catch(() => { this.$message.error('文件预览失败,请稍后重试') })
|
|
},
|
|
|
|
// 新增文件的modal
|
|
addUploadFileModal () {
|
|
let currentData = {
|
|
titleCon: 'OQC文件上传',
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
createBy: this.$store.state.user.name,
|
|
inspectionNo: this.detailData.inspectionNo,
|
|
remark: '',
|
|
folder: 'qcFQAS',
|
|
}
|
|
//打开组件 去做新增业务
|
|
this.$nextTick(() => {
|
|
this.$refs.qcFAIUploadFile.init(currentData)
|
|
})
|
|
},
|
|
|
|
// 上传项目图片
|
|
uploadImageModal (row) {
|
|
let currentData = {
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
createBy: this.$store.state.user.name,
|
|
inspectionNo: this.detailData.inspectionNo,
|
|
itemNo: row.itemNo,
|
|
folder: 'FQASItemImageFile'
|
|
}
|
|
//打开组件 去做新增业务
|
|
this.$nextTick(() => {
|
|
this.$refs.comQcItemImageUploadFile.init(currentData)
|
|
})
|
|
},
|
|
|
|
// 文件下载
|
|
downloadFile (row) {
|
|
downLoadObjectFile(row)
|
|
.then(({data}) => {
|
|
// 不限制文件下载类型
|
|
const blob = new Blob([data], {type: "application/octet-stream"})
|
|
// 下载文件名称
|
|
const fileName = row.fileName
|
|
// a标签下载
|
|
const linkNode = document.createElement('a')
|
|
// a标签的download属性规定下载文件的名称
|
|
linkNode.download = fileName
|
|
linkNode.style.display = 'none'
|
|
// 生成一个Blob URL
|
|
linkNode.href = URL.createObjectURL(blob)
|
|
document.body.appendChild(linkNode)
|
|
// 模拟在按钮上的一次鼠标单击
|
|
linkNode.click()
|
|
// 释放URL 对象
|
|
URL.revokeObjectURL(linkNode.href)
|
|
document.body.removeChild(linkNode)
|
|
})
|
|
},
|
|
|
|
// 预览
|
|
previewFile (row) {
|
|
// 预览文件
|
|
let image = ['jpg', 'jpeg', 'png', 'gif', 'bmp']
|
|
let type = ''
|
|
if (image.includes(row.fileType.toLowerCase())) {
|
|
type = 'image/' + row.fileType
|
|
}
|
|
let video = ['mp4', 'avi', 'mov', 'wmv', 'flv']
|
|
if (video.includes(row.fileType.toLowerCase())) {
|
|
type = 'video/' + row.fileType
|
|
}
|
|
let txt = ['txt']
|
|
if (txt.includes(row.fileType.toLowerCase())) {
|
|
type = 'text/plain'
|
|
}
|
|
let office = ['doc', 'docx', 'ppt', 'pptx', 'xls', 'xlsx']
|
|
if (office.includes(row.fileType.toLowerCase())) {
|
|
this.$message.warning(`暂不支持预览${row.fileType.toLowerCase()}文件`)
|
|
return
|
|
}
|
|
let pdf = ['pdf']
|
|
if (pdf.includes(row.fileType.toLowerCase())) {
|
|
type = 'application/pdf'
|
|
}
|
|
if (type === ''){
|
|
this.$message.warning(`暂不支持预览${row.fileType.toLowerCase()}文件`)
|
|
return;
|
|
}
|
|
// downLoadObjectFile(row).then(({data}) => {
|
|
// const blob = new Blob([data], { type: type });
|
|
// // 创建URL来生成预览
|
|
// const fileURL = URL.createObjectURL(blob);
|
|
// // alert(blob)
|
|
// localStorage.setItem("imgUrl",fileURL)
|
|
// window.open(window.location.origin+"/#/image",'_blank')
|
|
// // 在新标签页中打开文件预览
|
|
// // const newTab = window.open(fileURL, '_blank')
|
|
// })
|
|
downLoadObjectFile(row).then(({data}) => {
|
|
const blob = new Blob([data], { type: type });
|
|
// 创建URL来生成预览
|
|
const fileURL = URL.createObjectURL(blob);
|
|
if (type.includes('image')) { // 图片
|
|
localStorage.setItem("imgUrl",fileURL)
|
|
window.open(window.location.origin+"/#/image",'_blank')
|
|
} else {
|
|
// 在新标签页中打开文件预览
|
|
const newTab = window.open(fileURL, '_blank')
|
|
}
|
|
})
|
|
},
|
|
|
|
// 删除文件
|
|
deleteFile (row) {
|
|
let tempData = {
|
|
site: row.orderRef1,
|
|
inspectionNo: row.orderRef2,
|
|
buNo: row.orderRef4,
|
|
partNo: this.fileData.partNo,
|
|
inspectionTypeNo: '109'
|
|
}
|
|
this.$confirm('确定要删除此文件?', '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(() => {
|
|
deleteObjectFile(row).then(({data}) => {
|
|
if (data && data.code == 0) {
|
|
this.getFileContentData(tempData)
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {}
|
|
})
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
}).catch(() => {
|
|
})
|
|
},
|
|
|
|
// 获取基础数据列表S
|
|
getBaseList (val,type) {
|
|
this.tagNo = val
|
|
this.$nextTick(() => {
|
|
let strVal = ''
|
|
let conSql = ''
|
|
if (val === 1037) {
|
|
strVal = this.modalData.detailCodeNo
|
|
this.$refs.baseList.init(val, strVal)
|
|
}
|
|
if (val === 1040) {
|
|
strVal = this.modalData.inspectorNo
|
|
this.$refs.baseList.init(val, strVal)
|
|
}
|
|
if (val === 207) {
|
|
strVal = this.changeData.samplingProgrammeNo
|
|
conSql = " and bu_no = '" + this.changeData.buNo + "'"
|
|
this.$refs.baseList.init(val, strVal, conSql)
|
|
}
|
|
if (val === 208) {
|
|
strVal = this.changeData.samplingLevelNo
|
|
conSql = " and bu_no = '" + this.changeData.buNo + "'"
|
|
this.$refs.baseList.init(val, strVal, conSql)
|
|
}
|
|
if (val === 509) {
|
|
strVal = this.detailData.responsiblePerson
|
|
this.$refs.baseList.init(val, strVal)
|
|
}
|
|
})
|
|
},
|
|
|
|
// 列表方法的回调
|
|
getBaseData (val) {
|
|
if (this.tagNo === 1037) {
|
|
this.modalData.detailCodeNo = val.code_no
|
|
this.modalData.detailCodeDesc = val.code_desc
|
|
}
|
|
if (this.tagNo === 1040) {
|
|
this.modalData.inspectorNo = val.inspector_no
|
|
this.modalData.inspectorName = val.inspector_name
|
|
}
|
|
if (this.tagNo === 207) {
|
|
this.changeData.samplingProgrammeNo = val.sampling_programme_no
|
|
this.changeData.samplingProgrammeDesc = val.sampling_programme_desc
|
|
}
|
|
if (this.tagNo === 208) {
|
|
this.changeData.samplingLevelNo = val.sampling_level_no
|
|
this.changeData.samplingLevelDesc = val.sampling_level_desc
|
|
}
|
|
if (this.tagNo === 509) {
|
|
this.detailData.responsiblePerson = val.SupplierID
|
|
}
|
|
},
|
|
|
|
// 获取主信息数据列表
|
|
getDataList () {
|
|
this.searchData.limit = this.pageSize
|
|
this.searchData.page = this.pageIndex
|
|
qcOQCInspectionSearch(this.searchData).then(({data}) => {
|
|
if (data.code === 0) {
|
|
this.dataList = data.page.list
|
|
this.pageIndex = data.page.currPage
|
|
this.pageSize = data.page.pageSize
|
|
this.totalPage = data.page.totalCount
|
|
}
|
|
})
|
|
},
|
|
|
|
// 每页数
|
|
sizeChangeHandle (val) {
|
|
this.pageSize = val
|
|
this.pageIndex = 1
|
|
this.getDataList()
|
|
},
|
|
|
|
// 当前页
|
|
currentChangeHandle (val) {
|
|
this.pageIndex = val
|
|
this.getDataList()
|
|
},
|
|
|
|
// 多选
|
|
selectionChangeHandle (val) {
|
|
this.dataListSelections = val
|
|
},
|
|
|
|
async Transfer (type) {
|
|
if (type === '2') {
|
|
if (this.detailData.inspectionResult === '' || this.detailData.inspectionResult == null) {
|
|
this.$message.warning('请选择检验结论!')
|
|
return
|
|
}
|
|
if (this.detailData.inspectionResult === '不合格' && (this.detailData.disposalMeasures == null || this.detailData.disposalMeasures === '')) {
|
|
this.$message.warning('请选择处置措施!')
|
|
return
|
|
}
|
|
if (this.detailList.length > 0 && this.detailData.inspectionResult === '不合格') {
|
|
const flag = this.detailList.some(item => item.itemResult === 'N')
|
|
if (!flag) {
|
|
this.$message.warning('请选择不合格项目!')
|
|
return
|
|
}
|
|
}
|
|
if (this.detailData.inspectionResult !== '不合格') {
|
|
this.detailData.disposalMeasures = ''
|
|
this.detailData.disposalRemark = ''
|
|
}
|
|
}
|
|
this.saveDetailInformation(type)
|
|
},
|
|
|
|
// 新增明细信息
|
|
saveDetailInformation (type) {
|
|
this.saveInformationData.site = this.detailData.site
|
|
this.saveInformationData.buNo = this.detailData.buNo
|
|
this.saveInformationData.inspectionNo = this.detailData.inspectionNo
|
|
this.saveInformationData.disposalMeasures = this.detailData.disposalMeasures
|
|
this.saveInformationData.disposalRemark = this.detailData.disposalRemark
|
|
this.saveInformationData.inspectorNo = this.$store.state.user.name
|
|
this.saveInformationData.inspectionResult = this.detailData.inspectionResult
|
|
this.saveInformationData.inspectionRemark = this.detailData.inspectionRemark
|
|
this.saveInformationData.rollCount = this.detailData.rollCount
|
|
this.saveInformationData.samplingQty = this.detailData.samplingQty
|
|
this.saveInformationData.unqualifiedQty = this.detailData.unqualifiedQty
|
|
this.saveInformationData.partNo = this.detailData.partNo
|
|
this.saveInformationData.partDesc = this.detailData.partDesc
|
|
this.saveInformationData.operator = this.detailData.operator
|
|
this.saveInformationData.responsiblePerson = this.detailData.responsiblePerson
|
|
this.saveInformationData.itemList = JSON.parse(JSON.stringify(this.detailList))
|
|
this.saveInformationData.passQty = this.detailData.passQty == null ? 0 : this.detailData.passQty
|
|
this.saveInformationData.notPassQty = this.detailData.notPassQty == null ? 0 : this.detailData.notPassQty
|
|
this.saveInformationData.type = type
|
|
this.transferLoadFlag = true
|
|
saveFQASDetailedRecord(this.saveInformationData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.searchData.inspectionNo = ''
|
|
this.getDataList()
|
|
this.detailInformationFlag = false
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {}
|
|
})
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
}).finally(()=>{
|
|
this.transferLoadFlag = false
|
|
})
|
|
},
|
|
|
|
// 开始检验
|
|
actionModal (row) {
|
|
this.$confirm(`确认开始检验?`, '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(() => {
|
|
let tempData = {
|
|
site: row.site,
|
|
buNo: row.buNo,
|
|
inspectionNo: row.inspectionNo,
|
|
actionBy: this.$store.state.user.name,
|
|
state: '待检验'
|
|
}
|
|
actionFQASInspection(tempData).then(async ({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {
|
|
}
|
|
})
|
|
this.searchData.inspectionNo = row.inspectionNo
|
|
row.state = tempData.state
|
|
await this.getDataList()
|
|
this.detailModal(row)
|
|
} else {
|
|
await this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
})
|
|
},
|
|
|
|
// 明细记录信息查询
|
|
detailModal (row) {
|
|
this.detailData.site = row.site
|
|
this.detailData.buNo = row.buNo
|
|
this.detailData.inspectionNo = row.inspectionNo
|
|
this.detailData.partNo = row.partNo
|
|
this.detailData.partDesc = row.partDesc
|
|
this.detailData.rollQty = row.rollQty
|
|
this.detailData.samplingQty = row.samplingQty
|
|
this.detailData.unqualifiedQty = row.unqualifiedQty
|
|
this.detailData.unqualifiedQuantity = row.unqualifiedQuantity
|
|
this.detailData.submitFlag = row.submitFlag
|
|
this.detailData.disposalMeasures = row.disposalMeasures
|
|
this.detailData.disposalRemark = row.disposalRemark
|
|
this.detailData.inspectionResult = row.inspectionResult
|
|
this.detailData.inspectorNo = row.inspectorNo
|
|
this.detailData.inspectionRemark = row.inspectionRemark
|
|
this.detailData.umId = row.umId
|
|
this.detailData.umName = row.umName
|
|
this.detailData.rollCount = row.rollCount
|
|
this.detailData.operator = row.operator
|
|
this.detailData.operatorName = row.operatorName
|
|
this.detailData.responsiblePerson = row.responsiblePerson
|
|
this.detailData.responsiblePersonName = row.responsiblePersonName
|
|
this.detailData.state = row.state
|
|
this.detailData.spec = row.spec
|
|
if (row.state === '待检验') {
|
|
this.detailData.passQty = row.samplingQty
|
|
} else {
|
|
this.detailData.passQty = row.passQty
|
|
this.detailData.notPassQty = row.notPassQty
|
|
}
|
|
this.getInspectionFormData()
|
|
// this.acquisitionList = []
|
|
this.detailInformationFlag = true
|
|
},
|
|
|
|
// 检验单明细
|
|
getInspectionFormData () {
|
|
fqasDetailSearch(this.detailData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.detailList = data.rows
|
|
} else {
|
|
this.detailList = []
|
|
}
|
|
})
|
|
},
|
|
|
|
// 子明细记录信息查询
|
|
subDetailModal (row) {
|
|
this.subDetailData = row
|
|
this.pageIndex2 = 1
|
|
selectFQASSubDetailedRecord(this.subDetailData).then(({data}) => {
|
|
this.tableData = data.rows
|
|
})
|
|
this.batchAddData = {
|
|
samplingLocation: '',
|
|
samplingLocationB: '',
|
|
samplingNumber: ''
|
|
}
|
|
this.subDetailFlag = true
|
|
},
|
|
|
|
// 删除检验记录
|
|
deleteModal () {
|
|
if (this.FQASSelections.length === 0) {
|
|
this.$message.warning('请勾选要删除的检验单!')
|
|
return
|
|
}
|
|
this.$confirm(`是否删除该 `+ this.FQASSelections.length +` 条检验记录?`, '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(() => {
|
|
let tempData = {
|
|
site: '',
|
|
submitList: this.FQASSelections
|
|
}
|
|
fqasRecordDelete(tempData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.getDataList()
|
|
this.FQASSelections = []
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {}
|
|
})
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
}).catch(() => {
|
|
})
|
|
},
|
|
|
|
// 任务重载
|
|
overLoadModal () {
|
|
if (this.FQASSelections.length === 0) {
|
|
this.$message.warning('请勾选要重载的检验单!')
|
|
return
|
|
}
|
|
if (this.FQASSelections.every(val => val.state === '待检验' || val.state === '未开始')) {
|
|
this.$confirm(`是否重载该 `+ this.FQASSelections.length +` 条检验单?`, '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(() => {
|
|
let tempData = {
|
|
site: '',
|
|
submitList: this.FQASSelections
|
|
}
|
|
this.overLoading = true
|
|
fqasRecordOverLoad(tempData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.getDataList()
|
|
this.FQASSelections = []
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {}
|
|
})
|
|
this.overLoading = false
|
|
} else {
|
|
this.overLoading = false
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
}).catch(() => {
|
|
this.overLoading = false
|
|
})
|
|
})
|
|
} else {
|
|
this.$message.warning('检验单必须为待检验状态!')
|
|
return
|
|
}
|
|
|
|
},
|
|
|
|
// 审核按钮
|
|
submitResult () {
|
|
let tempData1 = '' // 记录不是待审核状态的单号
|
|
let tempData2 = '' // 记录处置措施未填写的单号
|
|
if (this.FQASSelections.length === 0) {
|
|
this.$message.warning('请勾选要审核的检验单!')
|
|
return
|
|
}
|
|
for (let i = 0; i < this.FQASSelections.length; i++) {
|
|
if (this.FQASSelections[i].state !== '待审核'){
|
|
tempData1 = tempData1 + this.FQASSelections[i].inspectionNo + '、'
|
|
}
|
|
if (this.FQASSelections[i].inspectionResult === '不合格' && (this.FQASSelections[i].disposalMeasures === '' || this.FQASSelections[i].disposalMeasures == null)) {
|
|
tempData2 = tempData2 + this.FQASSelections[i].inspectionNo + '、'
|
|
}
|
|
}
|
|
if (tempData1 !== '') {
|
|
tempData1 = tempData1.substring(0, tempData1.length - 1)
|
|
this.$message.warning('检验单号 ' + tempData1 + ' 不是待审核状态!')
|
|
return
|
|
}
|
|
if (tempData2 !== '') {
|
|
tempData2 = tempData2.substring(0, tempData2.length - 1)
|
|
this.$message.warning('检验单号 ' + tempData2 + ' 的处置措施未选择!')
|
|
return
|
|
}
|
|
this.$confirm(`已确认单据信息无误,确定审核该 ` + this.FQASSelections.length + ` 条记录`, '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(() => {
|
|
this.submitData.submitList = this.FQASSelections
|
|
saveFQASSubmitResult(this.submitData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.getDataList()
|
|
this.FQASSelections = []
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {}
|
|
})
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
}).catch(() => {
|
|
})
|
|
},
|
|
|
|
// 子明细每页数
|
|
sizeChangeHandle2 (val) {
|
|
this.pageSize2 = val
|
|
},
|
|
|
|
// 子明细当前页
|
|
currentChangeHandle2 (val) {
|
|
this.pageIndex2 = val
|
|
},
|
|
|
|
// 子明细方法
|
|
// 表格的新增
|
|
rowClassName ({ row, rowIndex }) {
|
|
row.xh = rowIndex + 1
|
|
row.rowI = this.tableData.indexOf(row) + 1
|
|
},
|
|
|
|
// 单选框选中数据
|
|
handleDetailSelectionChange(selection) {
|
|
this.checkedDetail = selection
|
|
},
|
|
|
|
// 点击新增更多
|
|
handleAddBtn (td) {
|
|
checkFQASIsSubmit(td).then(({data}) => {
|
|
if (data.flag !== 1) {
|
|
let obj = {
|
|
subDetailValue: '',
|
|
samplingLocation: '',
|
|
samplingLocationB: '',
|
|
subDetailValueB: '',
|
|
subDetailValueC: '',
|
|
subDetailValueD: '',
|
|
subDetailValueE: '',
|
|
}
|
|
this.tableData.push(obj)
|
|
} else {
|
|
this.$message.error('记录已提交')
|
|
}
|
|
})
|
|
},
|
|
|
|
// 批量新增操作
|
|
batchHandleAdd (td) {
|
|
checkFQASIsSubmit(td).then(({data}) => {
|
|
if (data.flag !== 1) {
|
|
this.batchHandleAddModalFlag = true
|
|
} else {
|
|
this.$alert("记录已提交!", '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
},
|
|
|
|
// 批量新增行
|
|
batchHandleAddModal () {
|
|
for (let i = 0; i < this.batchAddData.samplingNumber; i++) {
|
|
let obj = {
|
|
samplingLocation: this.batchAddData.samplingLocation,
|
|
samplingLocationB: this.batchAddData.samplingLocationB,
|
|
subDetailValue: '',
|
|
subDetailValueB: '',
|
|
subDetailValueC: '',
|
|
subDetailValueD: '',
|
|
subDetailValueE: '',
|
|
}
|
|
this.tableData.push(obj)
|
|
}
|
|
this.batchHandleAddModalFlag = false
|
|
},
|
|
|
|
// 回车事件
|
|
nextFocus1 (index) {
|
|
let a1 = `${index + 1}` + `a`
|
|
this.$nextTick(() => {
|
|
this.$refs[a1].focus()
|
|
})
|
|
},
|
|
nextFocus2 (index) {
|
|
let a2 = `${index + 1}` + `b`
|
|
this.$nextTick(() => {
|
|
this.$refs[a2].focus()
|
|
})
|
|
},
|
|
nextFocus3 (index) {
|
|
let a3 = `${index + 1}` + `c`
|
|
this.$nextTick(() => {
|
|
this.$refs[a3].focus()
|
|
})
|
|
},
|
|
nextFocus4 (index) {
|
|
let a = `${index + 1}` + `d`
|
|
this.$nextTick(() => {
|
|
this.$refs[a].focus()
|
|
})
|
|
},
|
|
nextFocus5 (index) {
|
|
let a = `${index + 1}` + `e`
|
|
this.$nextTick(() => {
|
|
this.$refs[a].focus()
|
|
})
|
|
},
|
|
nextFocus6 (index) {
|
|
let a = `${index + 1}` + `f`
|
|
this.$nextTick(() => {
|
|
this.$refs[a].focus()
|
|
})
|
|
},
|
|
nextFocus7 (index) {
|
|
let a = `${index + 1}` + `g`
|
|
this.$nextTick(() => {
|
|
this.$refs[a].focus()
|
|
})
|
|
},
|
|
|
|
focusNextInput (index, type) {
|
|
let aaa = ''
|
|
if (this.detailList.length - 1 === index) {
|
|
aaa = `${type}0`
|
|
} else {
|
|
aaa = `${type}${index + 1}`
|
|
}
|
|
this.$nextTick(() => {
|
|
this.$refs[aaa].focus()
|
|
})
|
|
},
|
|
|
|
//删除
|
|
handleDeleteBtn (td) {
|
|
checkFQASIsSubmit(td).then(({data}) => {
|
|
if (data.flag !== 1) {
|
|
if (this.checkedDetail.length === 0) {
|
|
this.$alert("请先选择要删除的数据", "提示", {
|
|
confirmButtonText: "确定",
|
|
})
|
|
} else {
|
|
this.$confirm("请是否确认删除该子明细记录?", "提示", {
|
|
confirmButtonText: "确定",
|
|
cancelButtonText: "取消",
|
|
type: "warning",
|
|
callback: (action) => {
|
|
if (action === "confirm") {
|
|
let val = this.checkedDetail
|
|
val.forEach((val, index) => {
|
|
this.tableData.splice(this.tableData.indexOf(val), 1)
|
|
if (this.templateTableData.length === 0) {
|
|
this.pageIndex2--
|
|
}
|
|
})
|
|
this.$message({
|
|
message: "删除成功!",
|
|
type: "success",
|
|
})
|
|
return
|
|
} else {
|
|
this.$message({
|
|
message: "已取消删除操作",
|
|
type: "warning",
|
|
})
|
|
return
|
|
}
|
|
},
|
|
})
|
|
}
|
|
} else {
|
|
this.$alert("记录已提交!", '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
},
|
|
|
|
// 新增子明细记录
|
|
saveSubDetailResult () {
|
|
for (let i = 0; i < this.tableData.length; i++) {
|
|
if(this.tableData[i].subDetailValue === '' || this.tableData[i].subDetailValue == null){
|
|
this.$message.warning('序号' + (i+1) +'未填写实测值!')
|
|
return
|
|
}
|
|
}
|
|
this.subDetailData.subDetailValues = this.tableData
|
|
saveFQASSubDetailed(this.subDetailData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
if (data.count > 0) {
|
|
this.subDetailData.itemResult = 'N'
|
|
this.subDetailData.unqualifiedQuantity = data.count
|
|
}
|
|
if (this.subDetailData.subDetailValues.length > 0) {
|
|
this.subDetailData.subDetailRecordNum = 1
|
|
} else {
|
|
this.subDetailData.subDetailRecordNum = -1
|
|
this.subDetailData.unqualifiedQuantity = 0
|
|
this.subDetailData.itemResult = 'Y'
|
|
}
|
|
this.subDetailFlag = false
|
|
this.tableData = []
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {}
|
|
})
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
},
|
|
|
|
// 更改检验方式
|
|
changeInspectionModal (row) {
|
|
this.changeData = {
|
|
site: row.site,
|
|
buNo: row.buNo,
|
|
inspectionNo: row.inspectionNo,
|
|
rollCount: row.rollCount,
|
|
inspectCode: '',
|
|
qtySample: '',
|
|
percentSample: '',
|
|
samplingProgrammeNo: '',
|
|
samplingProgrammeDesc: '',
|
|
samplingLevelNo: '',
|
|
samplingLevelDesc: '',
|
|
receiptNo: row.receiptNo,
|
|
receiptItemNo: row.receiptItemNo,
|
|
inspectionTypeNo: '108'
|
|
}
|
|
this.changeModalFlag = true
|
|
},
|
|
|
|
// 保存修改
|
|
changeInspectionWay () {
|
|
if (this.changeData.inspectCode === '' || this.changeData.inspectCode == null) {
|
|
this.$message.warning('请选择检验方式!')
|
|
return
|
|
}
|
|
if (this.changeData.inspectCode === '数量抽检' && (this.changeData.qtySample == null || this.changeData.qtySample === '' || this.changeData.qtySample === 0)) {
|
|
this.$message.warning('请填写抽检数量!')
|
|
return
|
|
}
|
|
if (this.changeData.inspectCode === '比例抽检' && (this.changeData.percentSample == null || this.changeData.percentSample === '' || this.changeData.percentSample === 0)) {
|
|
this.$message.warning('请填写抽检比例!')
|
|
return
|
|
}
|
|
if (this.changeData.inspectCode === '不固定抽检' && (this.changeData.samplingProgrammeNo == null || this.changeData.samplingProgrammeNo === '')) {
|
|
this.$message.warning('请选择抽样方案!')
|
|
return
|
|
}
|
|
if (this.changeData.inspectCode === '不固定抽检' && (this.changeData.samplingLevelNo === null || this.changeData.samplingLevelNo === '')) {
|
|
this.$message.warning('请选择检验水平!')
|
|
return
|
|
}
|
|
if (this.changeData.inspectCode === '数量抽检' && this.changeData.qtySample > this.changeData.rollCount) {
|
|
this.$message.warning('抽检数量不能大于送检数量,当前检验单送检数量为[]!')
|
|
return
|
|
}
|
|
changeInspectionWay(this.changeData).then(({data}) => {
|
|
if (data && data.code === 0) {
|
|
this.getDataList()
|
|
this.changeModalFlag = false
|
|
this.$message({
|
|
message: '操作成功',
|
|
type: 'success',
|
|
duration: 1500,
|
|
onClose: () => {}
|
|
})
|
|
} else {
|
|
this.$alert(data.msg, '错误', {
|
|
confirmButtonText: '确定'
|
|
})
|
|
}
|
|
})
|
|
},
|
|
|
|
// 校验用户是否收藏
|
|
favoriteIsOk () {
|
|
let userFavorite = {
|
|
userId: this.$store.state.user.id,
|
|
languageCode: this.$i18n.locale
|
|
}
|
|
userFavoriteList(userFavorite).then(({data}) => {
|
|
for (let i = 0; i < data.list.length; i++) {
|
|
if (this.$route.meta.menuId === data.list[i].menuId) {
|
|
this.favorite = true
|
|
}
|
|
}
|
|
})
|
|
},
|
|
|
|
// 收藏 OR 取消收藏
|
|
favoriteFunction () {
|
|
let userFavorite = {
|
|
userId: this.$store.state.user.id,
|
|
functionId: this.$route.meta.menuId,
|
|
}
|
|
if (this.favorite) {
|
|
removeUserFavorite(userFavorite).then(({data}) => {
|
|
this.$message.success(data.msg)
|
|
this.favorite = false
|
|
})
|
|
} else {
|
|
// 收藏
|
|
saveUserFavorite(userFavorite).then(({data}) => {
|
|
this.$message.success(data.msg)
|
|
this.favorite = true
|
|
})
|
|
}
|
|
},
|
|
|
|
//导出excel
|
|
async createExportData () {
|
|
this.searchData.limit = -1
|
|
this.searchData.page = 1
|
|
await qcOQCInspectionSearch(this.searchData).then(({data}) => {
|
|
this.exportList = data.page.list
|
|
})
|
|
return this.exportList
|
|
},
|
|
|
|
startDownload() {},
|
|
|
|
finishDownload() {},
|
|
|
|
fields () {
|
|
let json = "{"
|
|
this.columnList1.forEach((item, index) => {
|
|
if (index == this.columnList1.length - 1) {
|
|
json += "\"" + item.columnLabel + "\"" + ":" + "\"" + item.columnProp + "\""
|
|
} else {
|
|
json += "\"" + item.columnLabel + "\"" + ":" + "\"" + item.columnProp + "\"" + ","
|
|
}
|
|
})
|
|
json += "}"
|
|
let s = eval("(" + json + ")")
|
|
return s
|
|
},
|
|
|
|
// 动态列开始 获取 用户保存的 格式列
|
|
async getTableUserColumn (tableId, columnId) {
|
|
let queryTableUser = {
|
|
userId: this.$store.state.user.name,
|
|
functionId: this.$route.meta.menuId,
|
|
tableId: tableId,
|
|
status: true,
|
|
languageCode: this.$i18n.locale
|
|
}
|
|
await getTableUserListLanguage(queryTableUser).then(({data}) => {
|
|
if (data.rows.length > 0) {
|
|
//this.columnList1 = []
|
|
switch (columnId) {
|
|
case 1:
|
|
this.columnList1 = data.rows
|
|
break;
|
|
case 2:
|
|
this.detailColumnList = data.rows
|
|
break;
|
|
}
|
|
} else {
|
|
this.getColumnList(tableId, columnId)
|
|
}
|
|
})
|
|
},
|
|
|
|
// 获取 tableDefault 列
|
|
async getColumnList (tableId, columnId) {
|
|
let queryTable = {
|
|
functionId: this.$route.meta.menuId,
|
|
tableId: tableId,
|
|
languageCode: this.$i18n.locale
|
|
}
|
|
await getTableDefaultListLanguage(queryTable).then(({data}) => {
|
|
if (!data.rows.length == 0) {
|
|
switch (columnId) {
|
|
case 1:
|
|
this.columnList1 = data.rows
|
|
break;
|
|
case 2:
|
|
this.detailColumnList = data.rows
|
|
break;
|
|
}
|
|
}
|
|
})
|
|
},
|
|
|
|
/**
|
|
* 明细导入后将返回值回传给父组件
|
|
* @param val
|
|
*/
|
|
changeMyString (val) {
|
|
for (let i = 0; i < this.detailList.length; i++) {
|
|
if (val[this.detailList[i].itemNo] !== undefined) {
|
|
this.detailList[i].unqualifiedQuantity = val[this.detailList[i].itemNo]
|
|
if (val[this.detailList[i].itemNo] != null) {
|
|
this.detailList[i].subDetailRecordNum = 1
|
|
}
|
|
if (val[this.detailList[i].itemNo] > 0) {
|
|
this.detailList[i].itemResult = 'N'
|
|
}
|
|
}
|
|
}
|
|
},
|
|
|
|
//获取按钮的权限数据
|
|
getButtonAuthData () {
|
|
let searchFlag = this.isAuth(this.menuId+":search")
|
|
let checkFlag = this.isAuth(this.menuId+":check")
|
|
let overLoadFlag = this.isAuth(this.menuId+":overLoad")
|
|
let deleteFlag = this.isAuth(this.menuId+":delete")
|
|
let detailFlag = this.isAuth(this.menuId+":detail")
|
|
let fileFlag = this.isAuth(this.menuId+":file")
|
|
let changeFlag = this.isAuth(this.menuId+":change")
|
|
//处理页面的权限数据
|
|
this.authSearch = !searchFlag
|
|
this.authCheck = !checkFlag
|
|
this.authOverLoad = !overLoadFlag
|
|
this.authDelete = !deleteFlag
|
|
this.authDetail = !detailFlag
|
|
this.authFile = !fileFlag
|
|
this.authChange = !changeFlag
|
|
},
|
|
|
|
// ======================== OQC检验项目操作相关方法 ========================
|
|
openItemOperationDialog() {
|
|
this.itemOperationQuery = { itemNo: '', itemDesc: '' }
|
|
this.searchOQCItems()
|
|
this.itemOperationDialogFlag = true
|
|
},
|
|
async searchOQCItems() {
|
|
try {
|
|
const params = {
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
inspectionNo: this.detailData.inspectionNo,
|
|
itemNo: this.itemOperationQuery.itemNo || '',
|
|
itemDesc: this.itemOperationQuery.itemDesc || ''
|
|
}
|
|
const { data } = await getOQCItemList(params)
|
|
if (data && data.code === 0) {
|
|
this.availableItemList = data.row1 || []
|
|
this.selectedItemList = data.row2 || []
|
|
}
|
|
} catch (error) {
|
|
this.$message.error('查询检验项目失败')
|
|
}
|
|
},
|
|
availableItemClickRow(row) {
|
|
this.$refs.availableItemTable.toggleRowSelection(row)
|
|
},
|
|
availableItemSelectionChange(selection) {
|
|
this.availableItemSelections = selection
|
|
},
|
|
selectedItemClickRow(row) {
|
|
this.$refs.selectedItemTable.toggleRowSelection(row)
|
|
},
|
|
selectedItemSelectionChange(selection) {
|
|
this.selectedItemSelections = selection
|
|
},
|
|
async addInspectionItems() {
|
|
if (!this.availableItemSelections || this.availableItemSelections.length === 0) {
|
|
this.$message.warning('请选择要添加的项目')
|
|
return
|
|
}
|
|
this.$confirm('确认添加选中的检验项目吗?', '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(async () => {
|
|
try {
|
|
const params = {
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
inspectionNo: this.detailData.inspectionNo,
|
|
itemList: this.availableItemSelections.map(item => ({ itemNo: item.itemNo }))
|
|
}
|
|
const { data } = await addOQCItemDetails(params)
|
|
if (data && data.code === 0) {
|
|
this.$message.success('添加成功')
|
|
this.searchOQCItems()
|
|
} else {
|
|
this.$message.error(data.msg || '添加失败')
|
|
}
|
|
} catch (error) {
|
|
this.$message.error('添加失败,请检查')
|
|
}
|
|
}).catch(() => {
|
|
this.$message.info('已取消添加')
|
|
})
|
|
},
|
|
async deleteInspectionItems() {
|
|
if (!this.selectedItemSelections || this.selectedItemSelections.length === 0) {
|
|
this.$message.warning('请选择要移除的项目')
|
|
return
|
|
}
|
|
this.$confirm('确认移除选中的检验项目吗?(将同时删除该项目的子明细数据)', '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(async () => {
|
|
try {
|
|
const params = {
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
inspectionNo: this.detailData.inspectionNo,
|
|
itemList: this.selectedItemSelections.map(item => ({ itemNo: item.itemNo }))
|
|
}
|
|
const { data } = await deleteOQCItemDetails(params)
|
|
if (data && data.code === 0) {
|
|
this.$message.success('移除成功')
|
|
this.searchOQCItems()
|
|
} else {
|
|
this.$message.error(data.msg || '移除失败')
|
|
}
|
|
} catch (error) {
|
|
this.$message.error('移除失败,请检查')
|
|
}
|
|
}).catch(() => {
|
|
this.$message.info('已取消移除')
|
|
})
|
|
},
|
|
refreshInspectionDetailList() {
|
|
if (this.detailInformationFlag) {
|
|
this.getInspectionFormData()
|
|
}
|
|
},
|
|
|
|
// ======================== OQC模板导入相关方法 ========================
|
|
openTemplateImportDialog() {
|
|
this.templateQuery = { templateId: '', templateDesc: '' }
|
|
this.searchOQCTemplates()
|
|
this.templateImportDialogFlag = true
|
|
},
|
|
async searchOQCTemplates() {
|
|
try {
|
|
const params = {
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
templateId: this.templateQuery.templateId || '',
|
|
templateDesc: this.templateQuery.templateDesc || ''
|
|
}
|
|
const { data } = await getOQCTemplateList(params)
|
|
if (data && data.code === 0) {
|
|
this.templateList = data.rows || []
|
|
}
|
|
} catch (error) {
|
|
this.$message.error('查询模板失败')
|
|
}
|
|
},
|
|
templateClickRow(row) {
|
|
this.$refs.templateTable.toggleRowSelection(row)
|
|
},
|
|
templateSelectionChange(selection) {
|
|
this.templateSelections = selection
|
|
},
|
|
confirmImportTemplate() {
|
|
if (!this.templateSelections || this.templateSelections.length === 0) {
|
|
this.$message.warning('请选择要导入的模板')
|
|
return
|
|
}
|
|
this.$confirm(`确认导入选中的 ${this.templateSelections.length} 个模板吗?`, '提示', {
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning'
|
|
}).then(async () => {
|
|
this.importLoading = true
|
|
try {
|
|
const params = {
|
|
site: this.detailData.site,
|
|
buNo: this.detailData.buNo,
|
|
inspectionNo: this.detailData.inspectionNo,
|
|
templateList: this.templateSelections.map(item => ({ templateId: item.templateId }))
|
|
}
|
|
const { data } = await importOQCTemplateItems(params)
|
|
if (data && data.code === 0) {
|
|
this.$message.success(`导入成功,共导入 ${data.importCount || 0} 个检验项目`)
|
|
this.templateImportDialogFlag = false
|
|
this.templateSelections = []
|
|
this.getInspectionFormData()
|
|
} else {
|
|
this.$message.error(data.msg || '导入失败')
|
|
}
|
|
} catch (error) {
|
|
this.$message.error('导入失败,请检查')
|
|
} finally {
|
|
this.importLoading = false
|
|
}
|
|
}).catch(() => {
|
|
this.$message.info('已取消导入')
|
|
})
|
|
},
|
|
resetItemQuery() {
|
|
this.itemOperationQuery = { itemNo: '', itemDesc: '' }
|
|
this.searchOQCItems()
|
|
},
|
|
resetTemplateQuery() {
|
|
this.templateQuery = { templateId: '', templateDesc: '' }
|
|
this.searchOQCTemplates()
|
|
},
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
/* 搜索卡片样式 */
|
|
.search-card {
|
|
margin-bottom: 16px;
|
|
border-radius: 8px;
|
|
overflow: hidden;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.search-card:hover {
|
|
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
|
|
}
|
|
|
|
.search-card /deep/ .el-card__header {
|
|
padding: 5px 20px;
|
|
background: linear-gradient(135deg, #9ac3d0 20%, #b6c7dd 80%);
|
|
border-bottom: none;
|
|
}
|
|
|
|
.search-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
}
|
|
|
|
.header-left {
|
|
display: flex;
|
|
align-items: center;
|
|
color: #fff;
|
|
}
|
|
|
|
.header-left i {
|
|
font-size: 16px;
|
|
margin-right: 8px;
|
|
}
|
|
|
|
.header-title {
|
|
font-size: 14px;
|
|
font-weight: 600;
|
|
letter-spacing: 0.5px;
|
|
}
|
|
|
|
.header-right {
|
|
color: #fff;
|
|
}
|
|
|
|
.collapse-btn {
|
|
color: #fff;
|
|
font-weight: 500;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.collapse-btn:hover {
|
|
color: #f0f0f0;
|
|
transform: translateY(-1px);
|
|
}
|
|
|
|
.collapse-btn i {
|
|
transition: transform 0.3s ease;
|
|
}
|
|
|
|
/* 搜索表单样式 */
|
|
.search-form {
|
|
padding: 10px 0;
|
|
min-height: 0;
|
|
}
|
|
|
|
/* 卡片主体样式 */
|
|
.search-card /deep/ .el-card__body {
|
|
padding: 10px 8px;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
/* 收起时的样式 */
|
|
.search-card.collapsed /deep/ .el-card__body {
|
|
padding: 10px 8px;
|
|
}
|
|
|
|
.search-form /deep/ .el-form-item {
|
|
margin-bottom: 18px;
|
|
}
|
|
|
|
.search-form /deep/ .el-form-item__label {
|
|
font-weight: 500;
|
|
color: #606266;
|
|
padding-bottom: 6px;
|
|
}
|
|
|
|
.search-form /deep/ .el-input__inner,
|
|
.search-form /deep/ .el-textarea__inner {
|
|
border-radius: 6px;
|
|
border: 1px solid #DCDFE6;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.search-form /deep/ .el-input__inner:focus,
|
|
.search-form /deep/ .el-textarea__inner:focus {
|
|
border-color: #667eea;
|
|
box-shadow: 0 0 0 2px rgba(102, 126, 234, 0.1);
|
|
}
|
|
|
|
.search-form /deep/ .el-select {
|
|
width: 100%;
|
|
}
|
|
|
|
.search-form /deep/ .el-date-editor.el-input {
|
|
width: 100%;
|
|
}
|
|
|
|
/* 状态下拉框优化 */
|
|
.search-form /deep/ .status-select {
|
|
width: 100%;
|
|
}
|
|
|
|
.search-form /deep/ .status-select .el-select__tags {
|
|
max-width: calc(100% - 30px);
|
|
}
|
|
|
|
.search-form /deep/ .status-select .el-tag {
|
|
max-width: 100%;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
/* 操作按钮区域 */
|
|
.search-actions {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
padding: 8px 0 2px 0;
|
|
}
|
|
|
|
/* 展开时显示上边框 */
|
|
.search-card:not(.collapsed) .search-actions {
|
|
border-top: 1px solid #f0f0f0;
|
|
margin-top: 8px;
|
|
}
|
|
|
|
/* 收起时不显示上边框和上边距 */
|
|
.search-card.collapsed .search-actions {
|
|
border-top: none;
|
|
margin-top: 0;
|
|
padding-top: 0;
|
|
}
|
|
|
|
.action-left,
|
|
.action-right {
|
|
display: flex;
|
|
gap: 8px;
|
|
}
|
|
|
|
.search-actions .el-button {
|
|
border-radius: 4px;
|
|
padding: 5px 10px;
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.search-actions .el-button:hover {
|
|
transform: translateY(-2px);
|
|
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
|
|
}
|
|
|
|
.search-actions .el-button--primary {
|
|
background: #60aeff;
|
|
border-color: #60aeff;
|
|
}
|
|
|
|
.search-actions .el-button--primary:hover {
|
|
background: #7dbdff;
|
|
border-color: #7dbdff;
|
|
}
|
|
|
|
.search-actions .el-button--success {
|
|
background: #67C23A;
|
|
border-color: #67C23A;
|
|
}
|
|
|
|
.search-actions .el-button--success:hover {
|
|
background: #85ce61;
|
|
border-color: #85ce61;
|
|
}
|
|
|
|
.search-actions .el-button--danger {
|
|
background: #F56C6C;
|
|
border-color: #F56C6C;
|
|
}
|
|
|
|
.search-actions .el-button--danger:hover {
|
|
background: #f78989;
|
|
border-color: #f78989;
|
|
}
|
|
|
|
.search-actions .el-button--warning {
|
|
background: #E6A23C;
|
|
border-color: #E6A23C;
|
|
}
|
|
|
|
.search-actions .el-button--warning:hover {
|
|
background: #ebb563;
|
|
border-color: #ebb563;
|
|
}
|
|
|
|
/* 响应式设计 */
|
|
@media (max-width: 1200px) {
|
|
.search-actions {
|
|
flex-direction: column;
|
|
gap: 10px;
|
|
}
|
|
|
|
.action-left,
|
|
.action-right {
|
|
width: 100%;
|
|
justify-content: center;
|
|
}
|
|
}
|
|
|
|
/deep/ .redElSelect .el-input--suffix .el-input__inner{
|
|
color: red;
|
|
font-weight: bold;
|
|
}
|
|
/deep/ .greenElSelect .el-input--suffix .el-input__inner{
|
|
color: rgb(103,194,58);
|
|
font-weight: bold;
|
|
}
|
|
.numInput /deep/ .el-input__inner{
|
|
text-align: right;
|
|
}
|
|
/deep/ .inlineNumber input::-webkit-outer-spin-button,
|
|
/deep/ .inlineNumber input::-webkit-inner-spin-button {
|
|
-webkit-appearance: none;
|
|
|
|
}
|
|
/deep/ .inlineNumber input[type="number"]{
|
|
-moz-appearance: textfield;
|
|
padding-right: 5px !important;
|
|
}
|
|
.el-table /deep/ .cell{
|
|
height: auto;
|
|
line-height: 1.5;
|
|
}
|
|
|
|
/* ==================== OQC检验项目操作对话框样式 ==================== */
|
|
/deep/ .item-operation-dialog {
|
|
border-radius: 8px;
|
|
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
|
|
}
|
|
/deep/ .item-operation-dialog .el-dialog__header {
|
|
background: linear-gradient(135deg, #9ac3d0 20%, #b6c7dd 80%);
|
|
padding: 20px 24px;
|
|
border-radius: 8px 8px 0 0;
|
|
}
|
|
/deep/ .item-operation-dialog .el-dialog__title {
|
|
color: #ffffff;
|
|
font-size: 16px;
|
|
font-weight: 600;
|
|
letter-spacing: 0.5px;
|
|
}
|
|
/deep/ .item-operation-dialog .el-dialog__headerbtn .el-dialog__close {
|
|
color: #ffffff;
|
|
font-size: 20px;
|
|
font-weight: bold;
|
|
}
|
|
/deep/ .item-operation-dialog .el-dialog__headerbtn:hover .el-dialog__close {
|
|
color: #f0f0f0;
|
|
}
|
|
/deep/ .item-operation-dialog .el-dialog__body {
|
|
padding: 24px;
|
|
background: #f8f9fa;
|
|
}
|
|
.search-container {
|
|
background: #ffffff;
|
|
padding: 16px 20px;
|
|
border-radius: 6px;
|
|
margin-bottom: 20px;
|
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
|
|
}
|
|
.search-container .el-form-item {
|
|
margin-bottom: 0;
|
|
}
|
|
.search-container .el-form-item__label {
|
|
font-weight: 500;
|
|
color: #606266;
|
|
}
|
|
.item-operation-content {
|
|
display: flex;
|
|
gap: 16px;
|
|
align-items: stretch;
|
|
}
|
|
.item-panel {
|
|
flex: 1;
|
|
background: #ffffff;
|
|
border-radius: 6px;
|
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
|
|
overflow: hidden;
|
|
transition: all 0.3s ease;
|
|
}
|
|
.item-panel:hover {
|
|
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
|
|
}
|
|
.available-panel {
|
|
flex: 1.5;
|
|
}
|
|
.selected-panel {
|
|
flex: 1;
|
|
}
|
|
.panel-header {
|
|
padding: 8px 16px;
|
|
background: linear-gradient(135deg, #9ac3d0 20%, #b6c7dd 80%);
|
|
border-bottom: 2px solid #9ac3d0;
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 8px;
|
|
}
|
|
.panel-header i {
|
|
font-size: 18px;
|
|
color: #ffffff;
|
|
}
|
|
.panel-title {
|
|
font-size: 14px;
|
|
font-weight: 600;
|
|
color: #ffffff;
|
|
letter-spacing: 0.5px;
|
|
}
|
|
.item-count {
|
|
margin-left: auto;
|
|
font-size: 12px;
|
|
color: #ffffff;
|
|
background: rgba(255, 255, 255, 0.25);
|
|
padding: 2px 10px;
|
|
border-radius: 12px;
|
|
font-weight: 500;
|
|
}
|
|
.operation-table {
|
|
border: none !important;
|
|
}
|
|
.operation-table /deep/ .el-table__body tr:hover > td {
|
|
background-color: #f0f7ff !important;
|
|
}
|
|
.operation-table /deep/ .el-table__row.current-row > td {
|
|
background-color: #e6f2ff !important;
|
|
}
|
|
.operation-table /deep/ td {
|
|
border-bottom: 1px solid #f0f0f0;
|
|
}
|
|
.operation-table /deep/ .el-table__body {
|
|
font-size: 13px;
|
|
}
|
|
.operation-buttons {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
gap: 20px;
|
|
padding: 0 8px;
|
|
}
|
|
.operation-buttons .el-button {
|
|
width: 48px;
|
|
height: 48px;
|
|
font-size: 20px;
|
|
transition: all 0.3s ease;
|
|
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
|
|
}
|
|
.operation-buttons .el-button:hover {
|
|
transform: scale(1.1);
|
|
box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
|
|
}
|
|
.operation-buttons .el-button.is-disabled {
|
|
opacity: 0.4;
|
|
cursor: not-allowed;
|
|
}
|
|
.operation-buttons .el-button--primary {
|
|
background: linear-gradient(135deg, #409EFF 0%, #66b1ff 100%);
|
|
border: none;
|
|
}
|
|
.operation-buttons .el-button--danger {
|
|
background: linear-gradient(135deg, #F56C6C 0%, #f78989 100%);
|
|
border: none;
|
|
}
|
|
@media (max-width: 1200px) {
|
|
.item-operation-content {
|
|
flex-direction: column;
|
|
}
|
|
.operation-buttons {
|
|
flex-direction: row;
|
|
gap: 12px;
|
|
}
|
|
.operation-buttons .el-button {
|
|
width: 42px;
|
|
height: 42px;
|
|
font-size: 18px;
|
|
}
|
|
}
|
|
/deep/ .template-import-dialog {
|
|
border-radius: 8px;
|
|
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
|
|
}
|
|
/deep/ .template-import-dialog .el-dialog__header {
|
|
background: linear-gradient(135deg, #9ac3d0 20%, #b6c7dd 80%);
|
|
padding: 20px 24px;
|
|
border-radius: 8px 8px 0 0;
|
|
}
|
|
/deep/ .template-import-dialog .el-dialog__title {
|
|
color: #ffffff;
|
|
font-size: 16px;
|
|
font-weight: 600;
|
|
letter-spacing: 0.5px;
|
|
}
|
|
/deep/ .template-import-dialog .el-dialog__headerbtn .el-dialog__close {
|
|
color: #ffffff;
|
|
font-size: 20px;
|
|
font-weight: bold;
|
|
}
|
|
/deep/ .template-import-dialog .el-dialog__headerbtn:hover .el-dialog__close {
|
|
color: #f0f0f0;
|
|
}
|
|
/deep/ .template-import-dialog .el-dialog__body {
|
|
padding: 24px;
|
|
background: #f8f9fa;
|
|
}
|
|
.template-list-container {
|
|
background: #ffffff;
|
|
border-radius: 6px;
|
|
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
|
|
overflow: hidden;
|
|
transition: all 0.3s ease;
|
|
}
|
|
.template-list-container:hover {
|
|
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
|
|
}
|
|
.template-table {
|
|
border: none !important;
|
|
}
|
|
.template-table /deep/ .el-table__body tr:hover > td {
|
|
background-color: #f0f7ff !important;
|
|
}
|
|
.template-table /deep/ .el-table__row.current-row > td {
|
|
background-color: #e6f2ff !important;
|
|
}
|
|
.template-table /deep/ td {
|
|
border-bottom: 1px solid #f0f0f0;
|
|
}
|
|
.template-table /deep/ .el-table__body {
|
|
font-size: 13px;
|
|
}
|
|
.operation-btn {
|
|
position: relative;
|
|
padding: 8px 16px;
|
|
border: none;
|
|
border-radius: 4px;
|
|
font-size: 13px;
|
|
font-weight: 500;
|
|
cursor: pointer;
|
|
transition: all 0.3s ease;
|
|
overflow: hidden;
|
|
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
|
|
}
|
|
.operation-btn:hover {
|
|
transform: translateY(-1px);
|
|
box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);
|
|
}
|
|
.operation-btn:active {
|
|
transform: translateY(0);
|
|
}
|
|
.operation-btn i {
|
|
margin-right: 4px;
|
|
font-size: 13px;
|
|
}
|
|
.operation-btn span {
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
.item-operation-btn {
|
|
background: linear-gradient(135deg, #97a9f7 0%, #ac97df 100%);
|
|
color: #ffffff;
|
|
}
|
|
.item-operation-btn:hover {
|
|
background: linear-gradient(135deg, #97a9f7 0%, #ac97df 100%);
|
|
color: #ffffff;
|
|
}
|
|
.template-import-btn {
|
|
background: linear-gradient(135deg, #97a9f7 0%, #ac97df 100%);
|
|
color: #ffffff;
|
|
margin-left: 10px;
|
|
}
|
|
.template-import-btn:hover {
|
|
background: linear-gradient(135deg, #97a9f7 0%, #ac97df 100%);
|
|
color: #ffffff;
|
|
}
|
|
|
|
/* ==================== 检验单对话框样式 ==================== */
|
|
.oqc-inspection-dialog /deep/ .el-dialog__header {
|
|
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
|
padding: 20px 24px;
|
|
border-radius: 8px 8px 0 0;
|
|
}
|
|
|
|
.oqc-inspection-dialog /deep/ .el-dialog__title {
|
|
color: #ffffff;
|
|
font-size: 18px;
|
|
font-weight: 600;
|
|
letter-spacing: 0.5px;
|
|
}
|
|
|
|
.oqc-inspection-dialog /deep/ .el-dialog__headerbtn .el-dialog__close {
|
|
color: #ffffff;
|
|
font-size: 20px;
|
|
}
|
|
|
|
.oqc-inspection-dialog /deep/ .el-dialog__body {
|
|
padding: 0;
|
|
background: #f5f7fa;
|
|
}
|
|
|
|
/* 单据信息卡片 */
|
|
.inspection-info-card {
|
|
background: #ffffff;
|
|
padding: 0px 0px;
|
|
}
|
|
|
|
.info-section {
|
|
margin-bottom: 0;
|
|
background: #f9fafb;
|
|
border-radius: 6px;
|
|
padding: 12px;
|
|
border: 1px solid #e8eaed;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.info-section:hover {
|
|
box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
|
|
border-color: #d0d4d9;
|
|
}
|
|
|
|
.info-section:last-child {
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
.section-title {
|
|
display: flex;
|
|
align-items: center;
|
|
margin-bottom: 12px;
|
|
padding-bottom: 8px;
|
|
border-bottom: 2px solid #e8eaed;
|
|
font-size: 14px;
|
|
font-weight: 600;
|
|
color: #303133;
|
|
}
|
|
|
|
.section-title i {
|
|
font-size: 18px;
|
|
margin-right: 8px;
|
|
color: #667eea;
|
|
}
|
|
|
|
.info-row {
|
|
margin-bottom: 0 !important;
|
|
}
|
|
|
|
.info-item {
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
.info-item label {
|
|
display: block;
|
|
margin-bottom: 6px;
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
color: #606266;
|
|
}
|
|
|
|
.info-item label a {
|
|
color: #409eff;
|
|
text-decoration: none;
|
|
transition: color 0.3s;
|
|
}
|
|
|
|
.info-item label a:hover {
|
|
color: #66b1ff;
|
|
text-decoration: underline;
|
|
}
|
|
|
|
.info-item /deep/ .el-input--small .el-input__inner,
|
|
.info-item /deep/ .el-input-number--small .el-input__inner {
|
|
border-radius: 4px;
|
|
border: 1px solid #dcdfe6;
|
|
transition: all 0.3s;
|
|
}
|
|
|
|
.info-item /deep/ .el-input--small .el-input__inner:focus,
|
|
.info-item /deep/ .el-input-number--small .el-input__inner:focus {
|
|
border-color: #667eea;
|
|
box-shadow: 0 0 0 2px rgba(102, 126, 234, 0.1);
|
|
}
|
|
|
|
.info-item /deep/ .el-select {
|
|
width: 100%;
|
|
}
|
|
|
|
/* 操作按钮区域 */
|
|
.action-buttons {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
padding: 10px 12px;
|
|
background: #ffffff;
|
|
border-radius: 6px;
|
|
border: 1px solid #e8eaed;
|
|
margin-top: 10px;
|
|
}
|
|
|
|
.left-actions,
|
|
.right-actions {
|
|
display: flex;
|
|
gap: 10px;
|
|
}
|
|
|
|
.action-buttons .el-button {
|
|
border-radius: 6px;
|
|
font-weight: 500;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.action-buttons .el-button:hover {
|
|
transform: translateY(-2px);
|
|
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
|
|
}
|
|
|
|
/* 检验项目列表 */
|
|
.inspection-table-wrapper {
|
|
background: #ffffff;
|
|
padding: 0px 0px;
|
|
}
|
|
|
|
.table-header {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
margin-bottom: 10px;
|
|
margin-top: 10px;
|
|
border-bottom: 2px solid #e8eaed;
|
|
}
|
|
|
|
.table-title {
|
|
font-size: 15px;
|
|
font-weight: 600;
|
|
color: #303133;
|
|
display: flex;
|
|
align-items: center;
|
|
}
|
|
|
|
.table-title i {
|
|
font-size: 18px;
|
|
margin-right: 8px;
|
|
color: #667eea;
|
|
}
|
|
|
|
.inspection-table {
|
|
border-radius: 8px;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.inspection-table /deep/ .el-table__header-wrapper th {
|
|
background: linear-gradient(135deg, #f5f7fa 0%, #e8eaed 100%);
|
|
color: #303133;
|
|
font-weight: 600;
|
|
font-size: 13px;
|
|
padding: 12px 0;
|
|
}
|
|
|
|
.inspection-table /deep/ .el-table__body-wrapper .el-table__row {
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.inspection-table /deep/ .el-table__body-wrapper .el-table__row:hover {
|
|
background: #f5f7fa;
|
|
}
|
|
|
|
.inspection-table /deep/ .el-table__body-wrapper .el-table__row.el-table__row--striped {
|
|
background: #fafbfc;
|
|
}
|
|
|
|
.inspection-table /deep/ .el-table__body-wrapper .el-table__row.el-table__row--striped:hover {
|
|
background: #f0f2f5;
|
|
}
|
|
|
|
.inspection-table /deep/ .el-button--mini {
|
|
padding: 7px 10px;
|
|
border-radius: 4px;
|
|
font-size: 12px;
|
|
}
|
|
|
|
/* 底部操作按钮 */
|
|
.dialog-footer {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
gap: 12px;
|
|
padding: 12px 16px;
|
|
background: #ffffff;
|
|
border-top: 1px solid #e8eaed;
|
|
}
|
|
|
|
.dialog-footer .el-button {
|
|
min-width: 100px;
|
|
border-radius: 6px;
|
|
font-weight: 500;
|
|
transition: all 0.3s ease;
|
|
}
|
|
|
|
.dialog-footer .el-button:hover {
|
|
transform: translateY(-2px);
|
|
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
|
|
}
|
|
|
|
.dialog-footer .el-button--success {
|
|
background: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);
|
|
border: none;
|
|
}
|
|
|
|
.dialog-footer .el-button--success:hover {
|
|
background: linear-gradient(135deg, #15b39d 0%, #4af58e 100%);
|
|
}
|
|
|
|
.dialog-footer .el-button--primary:hover {
|
|
background: linear-gradient(135deg, #7b8ff5 0%, #8a5bb3 100%);
|
|
}
|
|
|
|
.dialog-footer .el-button--success {
|
|
background: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);
|
|
border: none;
|
|
}
|
|
|
|
.dialog-footer .el-button--success:hover {
|
|
background: linear-gradient(135deg, #15b39d 0%, #4af58e 100%);
|
|
}
|
|
</style>
|