| | |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div class="operationClass"> |
| | | |
| | | <el-tooltip class="item" effect="dark" content="查看" placement="top"> |
| | | <i class="el-icon-view" style="color: #42b983;cursor: pointer;margin-right: 15px;" @click="check('check',row)" /> |
| | | <i |
| | | class="el-icon-view" |
| | | style="color: #42b983;cursor: pointer;margin-right: 15px;" |
| | | @click="check('check',row)" |
| | | /> |
| | | </el-tooltip> |
| | | <el-tooltip class="item" effect="dark" content="编辑" placement="top"> |
| | | <i class="el-icon-edit-outline" @click="edit('edit',row)" /> |
| | |
| | | <el-input v-model="dialogForm.name" :disabled="operation==='check'" style="width: 200px" /> |
| | | </el-form-item> |
| | | <el-form-item label="描述"> |
| | | <el-input v-model="dialogForm.description" :disabled="operation==='check'" type="textarea" style="width: 200px" /> |
| | | <el-input |
| | | v-model="dialogForm.description" |
| | | :disabled="operation==='check'" |
| | | type="textarea" |
| | | style="width: 200px" |
| | | /> |
| | | </el-form-item> |
| | | </el-form> |
| | | <div style="margin-bottom: 10px"> |
| | |
| | | width="100" |
| | | fixed |
| | | /> |
| | | <el-table-column |
| | | prop="code" |
| | | label="检验标准编码(名称)" |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div v-if="row.isVisible===0" style="display: flex;"> |
| | | <div>{{ row.code }}</div> |
| | | <div style="margin-left: 10px">{{ row.name }}</div> |
| | | </div> |
| | | |
| | | <el-select |
| | | v-if="row.isVisible===1" |
| | | v-model="row.code" |
| | | filterable |
| | | :popper-append-to-body="false" |
| | | style="width: 400px;" |
| | | placeholder="请选择" |
| | | @change="val=>changeCode(val,row)" |
| | | > |
| | | <el-option |
| | | v-for="item in JYSelectArr" |
| | | :key="item.code" |
| | | :label="item.code+''+item.name" |
| | | :value="item.code" |
| | | /> |
| | | </el-select> |
| | | </template> |
| | | </el-table-column> |
| | | <!-- <el-table-column--> |
| | | <!-- prop="name"--> |
| | | <!-- label="检验标准名称"--> |
| | | <!-- prop="code"--> |
| | | <!-- label="检验标准编码(名称)"--> |
| | | <!-- >--> |
| | | <!-- <template slot-scope="{row}">--> |
| | | <!-- <div v-if="row.isVisible===0">{{ row.name }}</div>--> |
| | | <!-- <div v-if="row.isVisible===0" style="display: flex;">--> |
| | | <!-- <div>{{ row.code }}</div>--> |
| | | <!-- <div style="margin-left: 10px">{{ row.name }}</div>--> |
| | | <!-- </div>--> |
| | | <!-- <el-select--> |
| | | <!-- v-if="row.isVisible===1"--> |
| | | <!-- v-model="row.name"--> |
| | | <!-- v-model="row.code"--> |
| | | <!-- filterable--> |
| | | <!-- :popper-append-to-body="false"--> |
| | | <!-- style="width: 200px;"--> |
| | | <!-- style="width: 400px;"--> |
| | | <!-- placeholder="请选择"--> |
| | | <!-- @change="val=>changeName(val,row)"--> |
| | | <!-- @change="val=>changeCode(val,row)"--> |
| | | <!-- >--> |
| | | <!-- <el-option--> |
| | | <!-- v-for="item in JYSelectArr"--> |
| | | <!-- :key="item.code"--> |
| | | <!-- :label="item.name"--> |
| | | <!-- :label="item.code+''+item.name"--> |
| | | <!-- :value="item.code"--> |
| | | <!-- />--> |
| | | <!-- </el-select>--> |
| | | <!-- </template>--> |
| | | <!-- </el-table-column>--> |
| | | <el-table-column |
| | | prop="code" |
| | | label="检验标准编码" |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div v-if="row.isVisible===0">{{ row.code }}</div> |
| | | <el-select |
| | | v-if="row.isVisible===1" |
| | | v-model="row.code" |
| | | style="width: 200px;" |
| | | placeholder="请选择" |
| | | @change="val=>changeName(val,row)" |
| | | > |
| | | <el-option |
| | | v-for="item in JYSelectArr" |
| | | :key="item.name" |
| | | :label="item.code" |
| | | :value="item.name" |
| | | /> |
| | | </el-select> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="name" |
| | | label="检验标准名称" |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div v-if="row.isVisible===0">{{ row.name }}</div> |
| | | <el-select |
| | | v-if="row.isVisible===1" |
| | | v-model="row.name" |
| | | style="width: 200px;" |
| | | placeholder="请选择" |
| | | @change="val=>changeName(val,row)" |
| | | > |
| | | <el-option |
| | | v-for="item in JYSelectArr" |
| | | :key="item.code" |
| | | :label="item.name" |
| | | :value="item.code" |
| | | /> |
| | | </el-select> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="descr" |
| | | label="检验描述描述" |
| | |
| | | <el-table-column |
| | | v-if="operation!=='check'" |
| | | label="操作" |
| | | fixed="right" |
| | | > |
| | | <template slot-scope="{row}"> |
| | | <div class="operationClass"> |
| | |
| | | }, |
| | | JYTableData: [], // 对话框检验信息表格 |
| | | JYSelectArr: [], // 检验项目下拉数组 |
| | | JYSelectedArr: [] // 已选检验项目数组 |
| | | JYIsCancel: true |
| | | } |
| | | }, |
| | | created() { |
| | |
| | | item.isVisible = 0 |
| | | item.descr = item.stepcheckitem_desc |
| | | item.number = number |
| | | this.JYSelectedArr.push(item.code) |
| | | }) |
| | | this.$nextTick(() => { |
| | | this.$refs.JYTableData.doLayout() |
| | |
| | | this.dialogForm.enable = '' |
| | | this.dialogForm.description = '' |
| | | this.JYTableData = [] |
| | | this.JYSelectedArr = [] |
| | | this.getStepCheckItemSelect() |
| | | this.$refs.dialogForm.clearValidate() |
| | | }, |
| | | // 对话框取消 |
| | |
| | | this.JYSelectArr = res |
| | | }, |
| | | // 检验标准编码值改变 |
| | | changeCode(val, row) { |
| | | row.name = this.JYSelectArr.find(it => it.code === val).name |
| | | row.descr = this.JYSelectArr.find(it => it.code === val).descr |
| | | }, |
| | | // 检验标准名称值改变 |
| | | // changeName(val, row) { |
| | | // row.code = this.JYSelectArr.find(it => it.code === val).code |
| | | // changeCode(val, row) { |
| | | // row.name = this.JYSelectArr.find(it => it.code === val).name |
| | | // row.descr = this.JYSelectArr.find(it => it.code === val).descr |
| | | // }, |
| | | // 检验标准名称值改变 |
| | | changeName(val, row) { |
| | | const res = this.JYSelectArr.find(item => { |
| | | return item.code === val || item.name === val |
| | | }) |
| | | row.code = res.code |
| | | row.name = res.name |
| | | row.descr = res.descr |
| | | }, |
| | | // 检验新增 |
| | | JYadd() { |
| | | if (this.JYTableData.length > 0 && this.JYTableData[this.JYTableData.length - 1].isVisible === 1) { |
| | |
| | | number = number === 0 ? (10 + Math.random()) : number |
| | | const data = { code: '', name: '', descr: '', isVisible: 1, number } |
| | | this.JYTableData.push(data) |
| | | this.JYIsCancel = false |
| | | }, |
| | | JYedit(row) { |
| | | this.JYSelectedArr.forEach((item, index) => { |
| | | if (item === row.code) { |
| | | this.JYSelectedArr.splice(index, 1) |
| | | } |
| | | this.JYIsCancel = false |
| | | this.JYSelectArr.splice(0, 0, { |
| | | code: row.code, |
| | | name: row.name, |
| | | descr: row.descr |
| | | }) |
| | | |
| | | this.JYTableData.forEach((item, index) => { |
| | | if (item.code === row.code) { |
| | | item.isVisible = 1 |
| | | if (item.code === row.code && item.number === row.number) { |
| | | this.JYTableData.splice(index, 1, { |
| | | code: row.code, |
| | | name: row.name, |
| | | descr: row.descr, |
| | | isVisible: 1, |
| | | number: row.number |
| | | }) |
| | | } |
| | | }) |
| | | }, |
| | | JYdel(row) { |
| | | this.JYSelectArr.splice(0, 0, { |
| | | code: row.code, |
| | | name: row.name, |
| | | descr: row.descr |
| | | }) |
| | | |
| | | this.JYTableData.forEach((item, index) => { |
| | | if (item.number === row.number) { |
| | | this.JYTableData.splice(index, 1) |
| | | } |
| | | }) |
| | | |
| | | this.JYSelectedArr.forEach((item, index) => { |
| | | if (item === row.code) { |
| | | this.JYSelectedArr.splice(index, 1) |
| | | } |
| | | }) |
| | | }, |
| | | JYsave(row) { |
| | | if (row.code === '') { |
| | | return this.$message.info('检验标准编码(名称)不能为空!') |
| | | return this.$message.info('检验标准编码不能为空!') |
| | | } |
| | | // if (row.name === '') { |
| | | // return this.$message.info('检验标准名称不能为空!') |
| | | // } |
| | | if (row.name === '') { |
| | | return this.$message.info('检验标准名称不能为空!') |
| | | } |
| | | |
| | | if (this.JYSelectedArr.find(item => item === row.code) !== undefined) { |
| | | return this.$message.info('检验标准编码(名称)不能重复!') |
| | | } else { |
| | | this.JYSelectedArr.push(row.code) |
| | | } |
| | | this.JYSelectArr.forEach((item, index) => { |
| | | if (item.code === row.code) { |
| | | this.JYSelectArr.splice(index, 1) |
| | | } |
| | | }) |
| | | |
| | | this.JYTableData.forEach((item, index) => { |
| | | if (item.number === row.number) { |
| | |
| | | this.JYTableData.splice(index, 1) |
| | | } |
| | | }) |
| | | |
| | | this.JYSelectedArr.forEach((item, index) => { |
| | | if (item === row.code) { |
| | | this.JYSelectedArr.splice(index, 1) |
| | | } |
| | | }) |
| | | console.log(this.JYIsCancel) |
| | | if (this.JYIsCancel && row.code.toString().length > 0) { |
| | | this.JYSelectArr.splice(0, 0, { |
| | | code: row.code, |
| | | name: row.name, |
| | | descr: row.descr |
| | | }) |
| | | } |
| | | this.JYIsCancel = true |
| | | } |
| | | } |
| | | } |
| | |
| | | <!--公共页面样式--> |
| | | <style lang="scss" scoped> |
| | | $main_color: #42b983; |
| | | .el-button--text{ |
| | | .el-button--text { |
| | | font-size: 14px; |
| | | cursor: pointer; |
| | | } |
| | | |
| | | ::v-deep .el-select__caret { |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | } |
| | | |
| | | .el-icon-share ,.el-icon-delete,.el-icon-edit-outline{ |
| | | .el-icon-share, .el-icon-delete, .el-icon-edit-outline { |
| | | color: $main_color; |
| | | cursor: pointer; |
| | | } |
| | | .el-icon-edit-outline{ |
| | | |
| | | .el-icon-edit-outline { |
| | | margin-right: 15px; |
| | | } |
| | | |
| | |
| | | background-color: #f8f8fa; |
| | | } |
| | | |
| | | ::v-deep .el-table__body .el-table__row.hover-row td{ |
| | | background-color: #eaecef ; |
| | | ::v-deep .el-table__body .el-table__row.hover-row td { |
| | | background-color: #eaecef; |
| | | } |
| | | |
| | | ::v-deep .el-form--inline .el-form-item__label { |
| | |
| | | .body ::v-deep .el-form-item { |
| | | margin-bottom: 0; |
| | | } |
| | | |
| | | .userDialogVisible ::v-deep .el-form-item { |
| | | margin-bottom: 0; |
| | | } |