“zhuo”
2023-08-09 ae7722004ef0ce44416dd080650acc3e4cbea396
new file:   src/api/experiment/checkTheReport.js
new file: src/api/experiment/reportAuditing.js
modified: src/views/experiment/checkTheReport/index.vue
modified: src/views/experiment/reportAuditing/index.vue
已修改5个文件
已添加2个文件
437 ■■■■■ 文件已修改
.env.development 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
.env.production 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
.env.staging 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/experiment/checkTheReport.js 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/experiment/reportAuditing.js 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/experiment/checkTheReport/index.vue 210 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/experiment/reportAuditing/index.vue 202 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
.env.development
@@ -2,4 +2,5 @@
ENV = 'development'
# base api
VUE_APP_BASE_API = 'http://192.168.110.167:1234/'
# VUE_APP_BASE_API = 'http://192.168.110.167:1234/'
VUE_APP_BASE_API = 'http://localhost:1234/'
.env.production
@@ -3,5 +3,5 @@
# base api
# VUE_APP_BASE_API = '/prod-api'
VUE_APP_BASE_API = 'http://192.168.110.167:1234/'
VUE_APP_BASE_API = 'http://localhost:1234/'
.env.staging
@@ -5,6 +5,6 @@
# base api
# VUE_APP_BASE_API = '/stage-api'
VUE_APP_BASE_API = 'http://192.168.110.167:1234/'
VUE_APP_BASE_API = 'http://localhost:1234/'
src/api/experiment/checkTheReport.js
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,9 @@
import request from '@/utils/request'
export function selectAllReport(params) {
  return request({
    url: '/report/selectAllReport',
    method: 'get',
    params
  })
}
src/api/experiment/reportAuditing.js
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,9 @@
import request from '@/utils/request'
export function selectAllReportCheck(params) {
  return request({
    url: '/reportAuditing/selectAllReportAuditing',
    method: 'get',
    params
  })
}
src/views/experiment/checkTheReport/index.vue
@@ -1,13 +1,217 @@
<template>
  <div>检测报告</div>
  <div class="content-main">
    <div class="top-bar">
      <el-form ref="form" :inline="true">
        <el-form-item class="sermargin">
          <el-input
            v-model="input"
            class="input-form"
            placeholder="请直接输入样式编号/报告单号/样品编号/进行搜索或下拉选择进行组合查询"
            @keyup.enter.native="getData"
          />
        </el-form-item>
        <el-form-item>
          <el-button type="primary" @click="getData()">查询</el-button>
          <el-button type="primary" plain @click="resetData()">重置</el-button>
        </el-form-item>
      </el-form>
      <el-form>
        <el-button class="rightBtn" type="primary" icon="el-icon-document" @click="exportData">导出报告</el-button>
      </el-form>
    </div>
    <div class="library-table">
      <div class="table-header">
        <div class="search-bar">
          <el-radio-group v-model="checkStatus" @change="handleRadioChange">
            <el-radio-button>全部</el-radio-button>
            <el-radio-button label="0">待提交</el-radio-button>
            <el-radio-button label="1">待审核</el-radio-button>
            <el-radio-button label="2">已审核</el-radio-button>
          </el-radio-group>
        </div>
      </div>
      <div class="table-box">
        <el-table
          ref="reportTable"
          :max-height="800"
          :cell-style="{textAlign: 'center'}"
          :header-cell-style="{border:'0px',background:'#f5f7fa',color:'#606266',boxShadow: 'inset 0 1px 0 #ebeef5',textAlign: 'center'}"
          :data="reportTable"
          style="width: 100%"
        >
          <el-table-column
            type="selection"
            label=""
            min-width="5%"
          />
          <el-table-column
            prop="materialCode"
            label="样品编号"
            sortable
            min-width="10%"
          />
          <el-table-column
            prop="reportCode"
            label="报告单号"
            sortable
            min-width="10%"
          />
          <el-table-column
            prop="inspectionCode"
            label="申请单号"
            sortable
            min-width="10%"
          />
          <el-table-column
            prop="approver"
            label="审批人"
            min-width="5%"
          />
          <el-table-column
            prop="status"
            label="审批状态"
            min-width="8%"
          >
            <template slot-scope="scope">
              <span>
                <el-tag type="info">{{ scope.row.status == 0 ? '待提交' :
                  scope.row.status == 1 ? '待审核' :
                  scope.row.status == 2 ? '代签字' :'已完成' }}</el-tag>
              </span>
            </template></el-table-column>
          <el-table-column
            prop="conclusion"
            label="检验结论"
            min-width="10%"
          />
          <el-table-column
            prop="name"
            label="编制人"
            min-width="8%"
          />
          <el-table-column
            label="操作"
            min-width="8%"
          >
            <template slot-scope="scope">
              <el-button type="text" size="small" @click="handleClick(scope.row)">预览</el-button>
              <el-button type="text" size="small">打印</el-button>
            </template>
          </el-table-column>
        </el-table>
        <!-- åˆ†é¡µå™¨ -->
        <div>
          <el-pagination
            :current-page="page"
            :page-sizes="[10, 20, 30, 40]"
            :page-size="pageSize"
            layout="total, sizes, prev, pager, next, jumper"
            :total="total"
            @size-change="handleSizeChange"
            @current-change="handleCurrentChange"
          />
        </div>
      </div>
    </div>
  </div>
</template>
<script>
import { selectAllReport } from '@/api/experiment/checkTheReport'
export default {
  data() {
    return {
      input: '',
      checkStatus: undefined,
      reportTable: [],
      page: 1,
      total: 0,
      pageSize: 10
    }
  },
  created() {
    this.getData()
  },
  methods: {
    // çŠ¶æ€æŒ‰é’®
    handleRadioChange() {
      this.getData()
    },
    // æ¯é¡µæ¡æ•°æ”¹å˜æ—¶è§¦å‘ é€‰æ‹©ä¸€é¡µæ˜¾ç¤ºå¤šå°‘行
    handleSizeChange(val) {
      console.log(`每页 ${val} æ¡`)
      this.pageSize = val
      this.getData()
    },
    // å½“前页改变时触发 è·³è½¬å…¶ä»–页
    handleCurrentChange(val) {
      console.log(`当前页: ${val}`)
      this.page = val
      this.getData()
    },
    // é‡ç½®æŒ‰é’®
    resetData() {
      this.input = undefined
      this.page = 1
      this.pageSize = 10
      this.checkStatus = undefined
      this.getData()
    },
    // æŸ¥è¯¢åˆ—表
    async getData() {
      const params = {
        page: this.page,
        pageSize: this.pageSize,
        name: this.input ? this.input : undefined,
        status: this.checkStatus ? this.checkStatus : undefined
      }
      const { data } = await selectAllReport(params)
      this.reportTable = data.row
      this.total = data.total
    }
  }
}
</script>
<style lang="scss" scoped>
.top-bar{
    margin: -25px -15px;
    background: #fff;
    display: flex;
    justify-content: space-between;
    padding: 5px 24px 0px 24px;
    .input-form {
    width: 800px;
    }
}
.library-table{
      background-color: #fff;
      flex: 1;
      margin: 0px -15px;
      margin-top: 40px;
      display: flex;
      flex-direction: column;
      .table-header{
        padding: 20px;
        display: flex;
        justify-content: space-between;
        .el-form-item{
          margin-bottom: 30px !important;
        }
      }
      .table-box{
          padding: 0px 20px;
          margin-top: 0px;
          flex: 1;
          background: #fff;
          display: flex;
          flex-direction: column;
          >div:nth-child(2){
            display: flex;
            justify-content: end;
            margin: 10px 0;
          }
      }
    }
</style>
src/views/experiment/reportAuditing/index.vue
@@ -1,13 +1,209 @@
<template>
  <div>报告审核</div>
  <div class="content-main">
    <div class="top-bar">
      <el-form ref="form" :inline="true">
        <el-form-item class="sermargin">
          <el-input
            v-model="input"
            class="input-form"
            placeholder="请直接输入样式编号/报告编号/样品名称/进行搜索或下拉选择进行组合查询"
            @keyup.enter.native="getData"
          />
        </el-form-item>
        <el-form-item>
          <el-button type="primary" @click="getData()">查询</el-button>
          <el-button type="primary" plain @click="resetData()">重置</el-button>
        </el-form-item>
      </el-form>
      <el-form>
        <el-button class="rightBtn" type="primary" @click="exportData">审核</el-button>
      </el-form>
    </div>
    <div class="library-table">
      <div class="table-header">
        <div class="search-bar">
          <el-radio-group v-model="checkStatus" @change="handleRadioChange">
            <el-radio-button>全部</el-radio-button>
            <el-radio-button label="0">待提交</el-radio-button>
            <el-radio-button label="2">待通过</el-radio-button>
          </el-radio-group>
        </div>
      </div>
      <div class="table-box">
        <el-table
          ref="reportTable"
          :max-height="800"
          :cell-style="{textAlign: 'center'}"
          :header-cell-style="{border:'0px',background:'#f5f7fa',color:'#606266',boxShadow: 'inset 0 1px 0 #ebeef5',textAlign: 'center'}"
          :data="reportTable"
          style="width: 100%"
        >
          <el-table-column
            type="selection"
            label=""
            min-width="5%"
          />
          <el-table-column
            prop="materialCode"
            label="样品编号"
            min-width="10%"
          />
          <el-table-column
            prop="reportCode"
            label="报告单号"
            min-width="10%"
          />
          <el-table-column
            prop="materialName"
            label="样品名称"
            min-width="10%"
          />
          <el-table-column
            prop="status"
            label="审批状态"
            min-width="8%"
          >
            <template slot-scope="scope">
              <span>
                <el-tag type="warning">{{ scope.row.status == 0 ? '待提交' : '已审核' }}</el-tag>
              </span>
            </template></el-table-column>
          <el-table-column
            prop="approver"
            label="审批人"
            min-width="8%"
          />
          <el-table-column
            prop="submitTime"
            label="提交日期"
            min-width="8%"
          />
          <el-table-column
            prop="checkTime"
            label="审核日期"
            min-width="8%"
          />
          <el-table-column
            label="操作"
            min-width="8%"
          >
            <template slot-scope="scope">
              <el-button type="text" size="small" @click="handleClick(scope.row)">查看详细</el-button>
            </template>
          </el-table-column>
        </el-table>
        <!-- åˆ†é¡µå™¨ -->
        <div>
          <el-pagination
            :current-page="page"
            :page-sizes="[10, 20, 30, 40]"
            :page-size="pageSize"
            layout="total, sizes, prev, pager, next, jumper"
            :total="total"
            @size-change="handleSizeChange"
            @current-change="handleCurrentChange"
          />
        </div>
      </div>
    </div>
  </div>
</template>
<script>
import { selectAllReportCheck } from '@/api/experiment/reportAuditing'
export default {
  data() {
    return {
      input: '',
      checkStatus: undefined,
      reportTable: [],
      page: 1,
      total: 0,
      pageSize: 10
    }
  },
  created() {
    this.getData()
  },
  methods: {
    // çŠ¶æ€æŒ‰é’®
    handleRadioChange() {
      this.getData()
    },
    // æ¯é¡µæ¡æ•°æ”¹å˜æ—¶è§¦å‘ é€‰æ‹©ä¸€é¡µæ˜¾ç¤ºå¤šå°‘行
    handleSizeChange(val) {
      console.log(`每页 ${val} æ¡`)
      this.pageSize = val
      this.getData()
    },
    // å½“前页改变时触发 è·³è½¬å…¶ä»–页
    handleCurrentChange(val) {
      console.log(`当前页: ${val}`)
      this.page = val
      this.getData()
    },
    // é‡ç½®æŒ‰é’®
    resetData() {
      this.input = undefined
      this.page = 1
      this.pageSize = 10
      this.checkStatus = undefined
      this.getData()
    },
    // æŸ¥è¯¢åˆ—表
    async getData() {
      const params = {
        page: this.page,
        pageSize: this.pageSize,
        name: this.input ? this.input : undefined,
        status: this.checkStatus ? this.checkStatus : undefined
      }
      const { data } = await selectAllReportCheck(params)
      this.reportTable = data.row
      this.total = data.total
    }
  }
}
</script>
<style lang="scss" scoped>
.top-bar{
    margin: -25px -15px;
    background: #fff;
    display: flex;
    justify-content: space-between;
    padding: 5px 24px 0px 24px;
    .input-form {
    width: 800px;
    }
}
.library-table{
      background-color: #fff;
      flex: 1;
      margin: 0px -15px;
      margin-top: 40px;
      display: flex;
      flex-direction: column;
      .table-header{
        padding: 20px;
        display: flex;
        justify-content: space-between;
        .el-form-item{
          margin-bottom: 30px !important;
        }
      }
      .table-box{
          padding: 0px 20px;
          margin-top: 0px;
          flex: 1;
          background: #fff;
          display: flex;
          flex-direction: column;
          >div:nth-child(2){
            display: flex;
            justify-content: end;
            margin: 10px 0;
          }
      }
    }
</style>