소스 검색

dict 数据字典

yuwandanmian 1 년 전
부모
커밋
74768c89ed

+ 15 - 0
src/views/dict/category/index.vue

@@ -0,0 +1,15 @@
+<template>
+  <div>
+    22222
+  </div>
+</template>
+
+<script>
+export default {
+
+}
+</script>
+
+<style lang="sass" scoped>
+
+</style>

+ 154 - 0
src/views/dict/map/components/CreateDialog.vue

@@ -0,0 +1,154 @@
+<template>
+  <el-dialog
+    :title="titleStr"
+    :visible.sync="data.bSwitch"
+    width="30%"
+  >
+    <el-form ref="ruleForm" :model="ruleForm" :rules="rules" label-width="100px" class="demo-ruleForm">
+      <el-form-item label="质控项目" prop="title">
+        <el-input v-model="ruleForm.title" placeholder="请输入" />
+      </el-form-item>
+      <el-form-item label="错误描述" prop="notice">
+        <el-input v-model="ruleForm.notice" placeholder="请输入" />
+      </el-form-item>
+      <el-form-item label="质控分类" prop="category">
+        <el-select v-model="ruleForm.category" clearable placeholder="请选择" style="width: 100%;">
+          <el-option v-for="item of categorys" :key="item" :label="item" :value="item" />
+        </el-select>
+      </el-form-item>
+      <el-form-item label="扣分" prop="score">
+        <el-input v-model="ruleForm.score" placeholder="请输入" />
+      </el-form-item>
+      <el-form-item label="质控类型" prop="type">
+        <el-select v-model="ruleForm.type" clearable placeholder="请选择" style="width: 100%;">
+          <el-option v-for="item of types" :key="item" :label="item" :value="item" />
+        </el-select>
+      </el-form-item>
+      <el-form-item label="科室" prop="department">
+        <el-input v-model="ruleForm.department" placeholder="请输入" />
+      </el-form-item>
+      <el-form-item label="单项否决" prop="one_no">
+        <el-select v-model="ruleForm.one_no" clearable placeholder="请选择" style="width: 100%;">
+          <el-option v-for="item of oneNos" :key="item.name" :label="item.name" :value="item.value" />
+        </el-select>
+      </el-form-item>
+      <el-form-item label="质控节点" prop="node">
+        <el-input v-model="ruleForm.node" placeholder="请输入" />
+      </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 { createCaseRuleList } from '@/api/admin'
+export default {
+  props: {
+    data: {
+      type: Object,
+      default() {
+        return {
+          bSwitch: false,
+          row: {}
+        }
+      }
+    },
+    categorys: {
+      type: Array,
+      default() {
+        return []
+      }
+    },
+    types: {
+      type: Array,
+      default() {
+        return []
+      }
+    }
+  },
+  data() {
+    return {
+      ruleForm: {
+        title: '',
+        notice: '',
+        category: '',
+        score: '',
+        type: '',
+        department: '',
+        one_no: '',
+        node: ''
+      },
+      rules: {
+        title: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        notice: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        category: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        score: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        type: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        department: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        one_no: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ],
+        node: [
+          { required: true, message: '请输入', trigger: 'blur' }
+        ]
+      },
+      oneNos: [{ name: '否', value: 0 }, { name: '是', value: 1 }]
+    }
+  },
+  computed: {
+    titleStr() {
+      return this.data.row.id ? '编辑' : '新增'
+    }
+  },
+  created() {
+    if (this.data.row.id) {
+      const { title, notice, category, id, score, type, department, one_no, node } = this.data.row
+      this.ruleForm.title = title
+      this.ruleForm.notice = notice
+      this.ruleForm.category = category
+      this.ruleForm.id = id
+      this.ruleForm.score = score
+      this.ruleForm.type = type
+      this.ruleForm.department = department
+      this.ruleForm.node = node
+      this.ruleForm.one_no = one_no
+    }
+  },
+  methods: {
+    submitForm(formName) {
+      this.$refs[formName].validate(async(valid) => {
+        if (valid) {
+          createCaseRuleList(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>

+ 62 - 0
src/views/dict/map/components/SearchBox.vue

@@ -0,0 +1,62 @@
+<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="手术2.0代码" />
+      </el-form-item>
+      <el-form-item label="">
+        <el-input v-model="data.ssmc" clearable placeholder="手术2.0名称" />
+      </el-form-item>
+      <el-form-item label="">
+        <el-input v-model="data.ssnm" clearable placeholder="手术内码" />
+      </el-form-item>
+
+      <el-form-item label="">
+        <el-input v-model="data.ssysbm" clearable placeholder="手术3.0代码" />
+      </el-form-item>
+      <el-form-item label="">
+        <el-input v-model="data.ssysmc" clearable placeholder="手术3.0名称" />
+      </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>
+        <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: '',
+          ssysbm: '',
+          ssysmc: '',
+          sslb: '',
+          ssnm: ''
+        }
+      }
+    }
+  },
+  methods: {
+    onSubmit() {
+      this.$emit('search')
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+
+</style>

+ 183 - 0
src/views/dict/map/components/TableBox.vue

@@ -0,0 +1,183 @@
+<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=""
+        label="手术2.0"
+        align="center"
+      >
+        <el-table-column
+          prop="SSBM"
+          label="手术2.0代码"
+          align="center"
+        />
+        <el-table-column
+          prop="SSMC"
+          label="手术2.0名称"
+          align="center"
+        />
+      </el-table-column>
+      <el-table-column
+        prop=""
+        label="手术3.0"
+        align="center"
+      >
+        <el-table-column
+          prop="SSYSBM"
+          label="手术3.0代码"
+          align="center"
+        />
+        <el-table-column
+          prop="SSYSMC"
+          label="手术3.0名称"
+          align="center"
+        />
+      </el-table-column>
+      <el-table-column
+        prop="SSNM"
+        label="手术内码"
+        align="center"
+      />
+      <el-table-column
+        prop="SSLB"
+        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" :types="types" :categorys="categorys" @refresh="handleRefresh" />
+  </div>
+</template>
+
+<script>
+import CreateDialog from './CreateDialog.vue'
+import { createCaseRuleList, setCaseRuleshizhong } from '@/api/admin'
+
+export default {
+  components: {
+    CreateDialog
+  },
+  props: {
+    data: {
+      type: Array,
+      default() {
+        return []
+      }
+    },
+    loading: {
+      type: Boolean,
+      default() {
+        return false
+      }
+    },
+    categorys: {
+      type: Array,
+      default() {
+        return []
+      }
+    },
+    types: {
+      type: Array,
+      default() {
+        return []
+      }
+    }
+  },
+  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
+    },
+    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')
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.btn-box {
+  text-align: right;
+  margin-bottom: 15px;
+}
+</style>

+ 90 - 0
src/views/dict/map/index.vue

@@ -0,0 +1,90 @@
+<template>
+  <div class="app-container">
+    <SearchBoxVue :data="searchData" :types="types" :categorys="categorys" @search="handleSearch" />
+    <TableBoxVue :loading="loading" :types="types" :categorys="categorys" :data="tableData" style="margin-top: -40px;" @refresh="handleRefresh" />
+    <pagination
+      :auto-scroll="false"
+      :total="paginationData.total"
+      :page="paginationData.page"
+      :limit="paginationData.limit"
+      @pagination="handlePagination"
+    />
+  </div>
+</template>
+
+<script>
+import SearchBoxVue from './components/SearchBox.vue'
+import TableBoxVue from './components/TableBox.vue'
+import { caseRuleList } from '@/api/admin'
+
+export default {
+  components: {
+    SearchBoxVue,
+    TableBoxVue
+  },
+  data() {
+    return {
+      loading: false,
+      searchData: {
+        ssbm: '',
+        ssmc: '',
+        ssysbm: '',
+        ssysmc: '',
+        sslb: '',
+        ssnm: ''
+      },
+      tableData: [],
+      paginationData: {
+        total: 0,
+        page: 1,
+        limit: 10
+      }
+    }
+  },
+  created() {
+    this.getList()
+  },
+  methods: {
+    handleRefresh() {
+      this.getList()
+    },
+    async getList() {
+      const { ssbm, ssmc, ssysbm, ssysmc, sslb, ssnm } = this.searchData
+      const { page, limit } = this.paginationData
+      const params = {
+        ssbm,
+        ssmc,
+        ssysbm,
+        ssysmc,
+        sslb,
+        ssnm,
+        page,
+        page_size: limit
+      }
+      this.loading = true
+      caseRuleList(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()
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+
+</style>

+ 1 - 0
src/views/rule/case/components/TableBox.vue

@@ -6,6 +6,7 @@
     <el-table
       v-loading="loading"
       :data="data"
+      border
       style="width: 100%"
     >
       <el-table-column type="index" label="序号" width="80" fixed="left" align="center" />