yuwandanmian 1 éve
szülő
commit
f2f5b1eaec

+ 27 - 0
src/api/dict.js

@@ -26,3 +26,30 @@ export function ssczysSave(data) {
     data: data
   })
 }
+
+// 手术分类
+export function getSsczList(data) {
+  return request({
+    url: '/sscz/ssczList',
+    method: 'post',
+    data: data
+  })
+}
+
+// 手术分类 新增
+export function ssczAdd(data) {
+  return request({
+    url: '/sscz/ssczAdd',
+    method: 'post',
+    data: data
+  })
+}
+
+// 手术分类 编辑
+export function ssczSave(data) {
+  return request({
+    url: '/sscz/ssczSave',
+    method: 'post',
+    data: data
+  })
+}

+ 9 - 0
src/api/excel.js

@@ -76,3 +76,12 @@ export function ssczysExport(data) {
     data: data
   })
 }
+
+// 手术类别导出
+export function ssczExport(data) {
+  return request_blob({
+    url: `/sscz/ssczExport`,
+    method: 'post',
+    data: data
+  })
+}

+ 124 - 0
src/views/dict/category/components/CreateDialog.vue

@@ -0,0 +1,124 @@
+<template>
+  <el-dialog
+    :title="titleStr"
+    :visible.sync="data.bSwitch"
+    width="40%"
+  >
+    <el-form ref="ruleForm" :model="ruleForm" :rules="rules" label-width="140px" class="demo-ruleForm">
+      <el-form-item label="手术操作编码" prop="ssbm">
+        <el-input v-model="ruleForm.ssbm" placeholder="请输入" />
+      </el-form-item>
+      <el-form-item label="手术操作名称" prop="ssmc">
+        <el-input v-model="ruleForm.ssmc" placeholder="请输入" />
+      </el-form-item>
+      <el-form-item label="操作类型" prop="sslb">
+        <el-select v-model="ruleForm.sslb" filterable clearable placeholder="请选择">
+          <el-option label="介入治疗" value="介入治疗" />
+          <el-option label="手术" value="手术" />
+          <el-option label="治疗性操作" value="治疗性操作" />
+          <el-option label="诊断性操作" value="诊断性操作" />
+        </el-select>
+      </el-form-item>
+      <el-form-item label="录入选项" prop="lrxx">
+        <el-select v-model="ruleForm.lrxx" filterable clearable placeholder="请选择">
+          <el-option label="选择性" value="选择性" />
+          <el-option label="必选" value="必选" />
+        </el-select>
+      </el-form-item>
+    </el-form>
+    <span slot="footer" class="dialog-footer">
+      <el-button @click="data.bSwitch = false">取 消</el-button>
+      <el-button type="primary" @click="submitForm('ruleForm')">确 定</el-button>
+    </span>
+  </el-dialog>
+</template>
+
+<script>
+import { ssczAdd, ssczSave } from '@/api/dict'
+export default {
+  props: {
+    data: {
+      type: Object,
+      default() {
+        return {
+          bSwitch: false,
+          row: {}
+        }
+      }
+    }
+  },
+  data() {
+    return {
+      ruleForm: {
+        ssbm: '',
+        ssmc: '',
+        sslb: '',
+        lrxx: ''
+      },
+      rules: {
+        ssbm: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        ssmc: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        sslb: [
+          { required: true, message: '请选择', trigger: 'blur' }
+        ],
+        lrxx: [
+          { required: true, message: '请选择', trigger: 'blur' }
+        ]
+      }
+    }
+  },
+  computed: {
+    titleStr() {
+      return this.data.row.id ? '编辑' : '新增'
+    }
+  },
+  created() {
+    if (this.data.row.id) {
+      const {
+        SSBM,
+        SSMC,
+        SSLB,
+        LRXX,
+        id } = this.data.row
+      this.ruleForm.ssbm = SSBM
+      this.ruleForm.ssmc = SSMC
+      this.ruleForm.id = id
+      this.ruleForm.sslb = SSLB
+      this.ruleForm.lrxx = LRXX
+    }
+  },
+  methods: {
+    submitForm(formName) {
+      this.$refs[formName].validate(async(valid) => {
+        if (valid) {
+          if (this.ruleForm.id) {
+            ssczSave(this.ruleForm).then(res => {
+              this.data.bSwitch = false
+              this.$emit('refresh')
+              this.$message.success(res.m || '操作成功')
+            })
+          } else {
+            ssczAdd(this.ruleForm).then(res => {
+              this.data.bSwitch = false
+              this.$emit('refresh')
+              this.$message.success(res.m || '操作成功')
+            })
+          }
+        } else {
+          return false
+        }
+      })
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.demo-ruleForm {
+  width: 80%;
+}
+</style>

+ 56 - 0
src/views/dict/category/components/SearchBox.vue

@@ -0,0 +1,56 @@
+<template>
+  <div class="app-container">
+    <el-form :inline="true" :model="data" class="demo-form-inline">
+      <el-form-item label="">
+        <el-input v-model="data.ssbm" clearable placeholder="手术操作编码" />
+      </el-form-item>
+      <el-form-item label="">
+        <el-input v-model="data.ssmc" clearable placeholder="手术操作名称" />
+      </el-form-item>
+      <el-form-item label="">
+        <el-select v-model="data.sslb" filterable clearable placeholder="操作类型">
+          <el-option label="介入治疗" value="介入治疗" />
+          <el-option label="手术" value="手术" />
+          <el-option label="治疗性操作" value="治疗性操作" />
+          <el-option label="诊断性操作" value="诊断性操作" />
+        </el-select>
+      </el-form-item>
+      <el-form-item label="">
+        <el-select v-model="data.lrxx" filterable clearable placeholder="录入选项">
+          <el-option label="选择性" value="选择性" />
+          <el-option label="必选" value="必选" />
+        </el-select>
+      </el-form-item>
+      <el-form-item>
+        <el-button type="primary" @click="onSubmit">查询</el-button>
+      </el-form-item>
+    </el-form>
+  </div>
+</template>
+
+<script>
+export default {
+  props: {
+    data: {
+      type: Object,
+      default() {
+        return {
+          ssbm: '',
+          ssmc: '',
+          sslb: '',
+          lrxx: ''
+        }
+      }
+    }
+  },
+  methods: {
+    onSubmit() {
+      this.$emit('search')
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+
+</style>

+ 109 - 0
src/views/dict/category/components/TableBox.vue

@@ -0,0 +1,109 @@
+<template>
+  <div>
+    <div class="btn-box">
+      <el-button type="primary" icon="el-icon-plus" @click="onCreate">新增</el-button>
+      <el-button type="primary" icon="el-icon-download" @click="onExport">导出</el-button>
+    </div>
+    <el-table
+      v-loading="loading"
+      :data="data"
+      border
+      style="width: 100%"
+    >
+      <el-table-column
+        type="index"
+        label="序号"
+        width="80"
+        fixed="left"
+        align="center"
+      />
+      <el-table-column
+        prop="SSBM"
+        label="手术操作代码"
+        align="center"
+      />
+      <el-table-column
+        prop="SSMC"
+        label="手术操作名称"
+        align="center"
+      />
+      <el-table-column
+        prop="SSLB"
+        label="操作类型"
+        align="center"
+      />
+      <el-table-column
+        prop="LRXX"
+        label="录入选项"
+        align="center"
+      />
+      <el-table-column
+        prop=""
+        label="操作"
+        align="center"
+        fixed="right"
+      >
+        <template slot-scope="scope">
+          <el-button type="text" @click="onEdit(scope.row)">修改</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+    <!-- 新增、编辑 -->
+    <CreateDialog v-if="createData.bSwitch" :data="createData" @refresh="handleRefresh" />
+  </div>
+</template>
+
+<script>
+import CreateDialog from './CreateDialog.vue'
+
+export default {
+  components: {
+    CreateDialog
+  },
+  props: {
+    data: {
+      type: Array,
+      default() {
+        return []
+      }
+    },
+    loading: {
+      type: Boolean,
+      default() {
+        return false
+      }
+    }
+  },
+  data() {
+    return {
+      createData: {
+        bSwitch: false,
+        row: {}
+      }
+    }
+  },
+  methods: {
+    onCreate() {
+      this.createData.row = {}
+      this.createData.bSwitch = true
+    },
+    onEdit(row) {
+      this.createData.row = row
+      this.createData.bSwitch = true
+    },
+    handleRefresh() {
+      this.$emit('refresh')
+    },
+    onExport() {
+      this.$emit('export')
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.btn-box {
+  text-align: right;
+  margin-bottom: 15px;
+}
+</style>

+ 102 - 4
src/views/dict/category/index.vue

@@ -1,15 +1,113 @@
 <template>
-  <div>
-    22222
+  <div class="app-container">
+    <SearchBoxVue :data="searchData" @search="handleSearch" />
+    <TableBoxVue :loading="loading" :data="tableData" style="margin-top: -40px;" @refresh="handleRefresh" @export="handleExport" />
+    <pagination
+      :auto-scroll="false"
+      :total="paginationData.total"
+      :page="paginationData.page"
+      :limit="paginationData.limit"
+      @pagination="handlePagination"
+    />
   </div>
 </template>
 
 <script>
-export default {
+import SearchBoxVue from './components/SearchBox.vue'
+import TableBoxVue from './components/TableBox.vue'
+import { getSsczList } from '@/api/dict'
+import { ssczExport } from '@/api/excel'
 
+export default {
+  components: {
+    SearchBoxVue,
+    TableBoxVue
+  },
+  data() {
+    return {
+      loading: false,
+      searchData: {
+        ssbm: '',
+        ssmc: '',
+        sslb: '',
+        lrxx: ''
+      },
+      tableData: [],
+      paginationData: {
+        total: 0,
+        page: 1,
+        limit: 10
+      }
+    }
+  },
+  created() {
+    this.getList()
+  },
+  methods: {
+    handleRefresh() {
+      this.getList()
+    },
+    async getList() {
+      const {
+        ssbm,
+        ssmc,
+        sslb,
+        lrxx
+      } = this.searchData
+      const { page, limit } = this.paginationData
+      const params = {
+        ssbm,
+        ssmc,
+        sslb,
+        lrxx,
+        page,
+        page_size: limit
+      }
+      this.loading = true
+      getSsczList(params).then(res => {
+        const { p } = res
+        this.paginationData.total = p.count
+        this.tableData = p.list
+      }).catch(error => {
+        console.log(error)
+      }).finally(() => {
+        this.loading = false
+      })
+    },
+    handlePagination(param) {
+      this.paginationData.page = param.page
+      this.paginationData.limit = param.limit
+      this.getList()
+    },
+    handleSearch() {
+      this.paginationData.page = 1
+      this.getList()
+    },
+    handleExport() {
+      ssczExport(this.searchData).then((res) => {
+        const content = res.data // 后台返回二进制数据
+        const blob = new Blob([content])
+        const fileName = `手术类别.csv`
+        if ('download' in document.createElement('a')) {
+          // 非IE下载
+          const elink = document.createElement('a')
+          elink.download = fileName
+          elink.style.display = 'none'
+          elink.href = URL.createObjectURL(blob)
+          document.body.appendChild(elink)
+          elink.click()
+          URL.revokeObjectURL(elink.href) // 释放URL 对象
+          document.body.removeChild(elink)
+        } else {
+          // IE10+下载
+          navigator.msSaveBlob(blob, fileName)
+        }
+      })
+    }
+  }
 }
 </script>
 
-<style lang="sass" scoped>
+<style lang="scss" scoped>
 
 </style>

+ 2 - 2
src/views/dict/map/components/CreateDialog.vue

@@ -74,10 +74,10 @@ export default {
           { required: true, message: '请输入', trigger: 'blur' }
         ],
         sslb: [
-          { required: true, message: '请输入', trigger: 'blur' }
+          { required: true, message: '请选择', trigger: 'blur' }
         ],
         ssnm: [
-          { required: true, message: '请选择', trigger: 'blur' }
+          { required: true, message: '请输入', trigger: 'blur' }
         ]
       }
     }

+ 1 - 56
src/views/dict/map/components/TableBox.vue

@@ -71,13 +71,12 @@
       </el-table-column>
     </el-table>
     <!-- 新增、编辑 -->
-    <CreateDialog v-if="createData.bSwitch" :data="createData" :types="types" :categorys="categorys" @refresh="handleRefresh" />
+    <CreateDialog v-if="createData.bSwitch" :data="createData" @refresh="handleRefresh" />
   </div>
 </template>
 
 <script>
 import CreateDialog from './CreateDialog.vue'
-import { createCaseRuleList, setCaseRuleshizhong } from '@/api/admin'
 
 export default {
   components: {
@@ -95,18 +94,6 @@ export default {
       default() {
         return false
       }
-    },
-    categorys: {
-      type: Array,
-      default() {
-        return []
-      }
-    },
-    types: {
-      type: Array,
-      default() {
-        return []
-      }
     }
   },
   data() {
@@ -126,48 +113,6 @@ export default {
       this.createData.row = row
       this.createData.bSwitch = true
     },
-    handleStatusChange(row) {
-      const index = row.status ? 1 : 0
-      this.$confirm('确认要更改为 <strong>' + ['停用', '正常'][index] + '</strong> 状态吗?', '提示', {
-        dangerouslyUseHTMLString: true,
-        confirmButtonText: '确定',
-        cancelButtonText: '取消',
-        type: 'warning'
-      }).then(() => {
-        createCaseRuleList(row).then(res => {
-          this.data.bSwitch = false
-          this.$emit('refresh')
-          this.$message.success(res.m || '操作成功')
-        }).catch(function() {
-          row.status = row.status === 0 ? 1 : 0
-        })
-      }).catch(function() {
-        row.status = row.status === 0 ? 1 : 0
-      })
-    },
-    handleIsShizhongChange(row) {
-      const index = row.is_shizhong ? 1 : 0
-      this.$confirm('确认要更改为 <strong>' + ['不同步', '同步'][index] + '</strong> 状态吗?', '提示', {
-        dangerouslyUseHTMLString: true,
-        confirmButtonText: '确定',
-        cancelButtonText: '取消',
-        type: 'warning'
-      }).then(() => {
-        const params = {
-          id: row.id,
-          status: row.is_shizhong
-        }
-        setCaseRuleshizhong(params).then(res => {
-          this.data.bSwitch = false
-          this.$emit('refresh')
-          this.$message.success(res.m || '操作成功')
-        }).catch(function() {
-          row.is_shizhong = row.is_shizhong ? 0 : 1
-        })
-      }).catch(function() {
-        row.is_shizhong = row.is_shizhong ? 0 : 1
-      })
-    },
     handleRefresh() {
       this.$emit('refresh')
     },