样本库
This commit is contained in:
parent
05d17a539e
commit
7ecc73131e
|
|
@ -0,0 +1,46 @@
|
|||
import request from '@/utils/request'
|
||||
|
||||
// 数据管理->样本库管理->查询样本库列表
|
||||
export function sampleListAPI(params) {
|
||||
return request({
|
||||
url: '/smartPlatform/data/sample/getSampleList',
|
||||
method: 'GET',
|
||||
params
|
||||
})
|
||||
}
|
||||
|
||||
// 数据管理->样本库管理->新增样本库
|
||||
export function addSampleDataAPI(data) {
|
||||
return request({
|
||||
url: '/smartPlatform/data/sample/addSampleData',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
|
||||
// 数据管理->样本库管理->修改样本库
|
||||
export function editSampleDataAPI(data) {
|
||||
return request({
|
||||
url: '/smartPlatform/data/sample/editSampleData',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
|
||||
// 数据管理->样本库管理->删除样本库
|
||||
export function delSampleDataAPI(data) {
|
||||
return request({
|
||||
url: '/smartPlatform/data/sample/delSampleData',
|
||||
method: 'post',
|
||||
data
|
||||
})
|
||||
}
|
||||
|
||||
// 数据管理->样本库管理->样本库详情
|
||||
export function getSampleDetailAPI(params) {
|
||||
return request({
|
||||
url: '/smartPlatform/data/sample/getSampleDetail',
|
||||
method: 'get',
|
||||
params
|
||||
})
|
||||
}
|
||||
|
|
@ -0,0 +1,244 @@
|
|||
<template>
|
||||
<!-- 小型弹窗,用于完成,删除,保存等操作 -->
|
||||
<el-dialog class="l-dialog" :class="lDialog" :title="title" :visible.sync="dialogVisible" :showClose="true"
|
||||
:closeOnClickModal="false" @close="handleClose" :append-to-body="true">
|
||||
<div>
|
||||
<el-form :model="form" :rules="rules" ref="ruleForm" label-width="110px" label-position="top">
|
||||
<el-form-item label="样本库名称" prop="sampleLibraryName">
|
||||
<el-input class="form-item" v-model="form.sampleLibraryName" clearable show-word-limit
|
||||
placeholder="请输入样本库名称" maxlength="32"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="样本库标签" prop="sampleLibraryLabel">
|
||||
<el-select class="form-item" v-model="form.sampleLibraryLabel" clearable show-word-limit multiple
|
||||
placeholder="请选择样本库标签">
|
||||
<el-option v-for="item in dict.type.sample_label" :key="item.value" :label="item.label"
|
||||
:value="item.value"></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="数据类型" prop="sampleLibraryType">
|
||||
<el-select class="form-item" v-model="form.sampleLibraryType" clearable show-word-limit
|
||||
placeholder="请选择数据类型">
|
||||
<el-option v-for="item in dict.type.sample_data_type" :key="item.value" :label="item.label"
|
||||
:value="item.value"></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="描述" prop="sampleLibraryDesc">
|
||||
<el-input type="textarea" :autosize="{ minRows: 2, maxRows: 4 }" class="form-item"
|
||||
v-model.trim="form.sampleLibraryDesc" clearable show-word-limit placeholder="请输入描述"
|
||||
maxlength="200"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</div>
|
||||
<span slot="footer" class="dialog-footer">
|
||||
<el-button type="primary" class="confirm-btn" :disabled="disabled"
|
||||
@click="submitForm('ruleForm')">确认</el-button>
|
||||
<el-button class="cancel-btn" @click="handleClose" :disabled="disabled">取消</el-button>
|
||||
</span>
|
||||
</el-dialog>
|
||||
</template>
|
||||
<script>
|
||||
import _ from 'lodash'
|
||||
import { addSampleDataAPI, editSampleDataAPI, getSampleDetailAPI } from '@/api/data/sample'
|
||||
const CONSTANT_PARAMS = {
|
||||
type: 'edit'
|
||||
};
|
||||
export default {
|
||||
name: "SampleForm",
|
||||
props: ["width", "rowData", "title", "disabled", "isAdd"],
|
||||
dicts: ['sample_label', 'sample_data_type'],
|
||||
data() {
|
||||
return {
|
||||
lDialog: this.width > 500 ? "w700" : "w500",
|
||||
dialogVisible: true,
|
||||
form: {
|
||||
sampleLibraryId: null,
|
||||
sampleLibraryName: '',
|
||||
sampleLibraryLabel: [],
|
||||
sampleLibraryType: null,
|
||||
sampleLibraryDesc: '',
|
||||
},
|
||||
rules: {
|
||||
sampleLibraryName: [
|
||||
{ required: true, message: '样本库名称不能为空', trigger: 'blur' }
|
||||
],
|
||||
sampleLibraryLabel: [
|
||||
{ required: true, message: '样本库标签不能为空', trigger: 'blur' }
|
||||
],
|
||||
sampleLibraryType: [
|
||||
{ required: true, message: '数据类型不能为空', trigger: 'blur' }
|
||||
],
|
||||
},
|
||||
};
|
||||
},
|
||||
watch: {
|
||||
isAdd: {
|
||||
handler(newVal) {
|
||||
if (newVal === CONSTANT_PARAMS.type) {
|
||||
this.initFormData();
|
||||
}
|
||||
},
|
||||
immediate: true,
|
||||
},
|
||||
},
|
||||
computed: {
|
||||
isAddData() {
|
||||
return this.isAdd === CONSTANT_PARAMS.type;
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
/** 初始化表单数据 */
|
||||
async initFormData() {
|
||||
const { data } = await getSampleDetailAPI({ sampleLibraryId: this.rowData.sampleLibraryId });
|
||||
if (data) {
|
||||
this.form = {
|
||||
...this.form,
|
||||
...data,
|
||||
sampleLibraryLabel: data.sampleLibraryLabel ? data.sampleLibraryLabel.split(',') : []
|
||||
};
|
||||
}
|
||||
},
|
||||
/*关闭弹窗 */
|
||||
handleClose() {
|
||||
this.dialogVisible = false;
|
||||
this.$emit("closeDialog");
|
||||
},
|
||||
/**确认弹窗 */
|
||||
sureBtnClick() {
|
||||
this.dialogVisible = false;
|
||||
this.$emit("closeDialog");
|
||||
},
|
||||
/**重置表单*/
|
||||
reset() {
|
||||
this.form = {
|
||||
sampleLibraryId: null,
|
||||
sampleLibraryName: '',
|
||||
sampleLibraryLabel: [],
|
||||
sampleLibraryType: null,
|
||||
sampleLibraryDesc: '',
|
||||
};
|
||||
this.resetForm("ruleForm");
|
||||
},
|
||||
handleReuslt(res) {
|
||||
this.$modal.msgSuccess(res.msg);
|
||||
this.reset();
|
||||
this.$emit('handleQuery');
|
||||
this.handleClose();
|
||||
},
|
||||
/**验证 */
|
||||
submitForm(formName) {
|
||||
this.$refs[formName].validate(valid => {
|
||||
if (valid) {
|
||||
// 显示遮罩层
|
||||
this.loading = this.$loading({
|
||||
lock: true,
|
||||
text: "数据提交中,请稍候...",
|
||||
background: 'rgba(0,0,0,0.5)',
|
||||
target: this.$el.querySelector('.el-dialog') || document.body
|
||||
})
|
||||
let params = _.cloneDeep(this.form);
|
||||
params.sampleLibraryLabel = params.sampleLibraryLabel.join(',');
|
||||
if (!this.isAddData) { // 新增
|
||||
addSampleDataAPI(params).then(res => {
|
||||
this.loading.close();
|
||||
if (res.code === 200) {
|
||||
this.handleReuslt(res);
|
||||
} else {
|
||||
this.$modal.msgError(res.msg);
|
||||
}
|
||||
}).catch(error => {
|
||||
this.loading.close();
|
||||
this.$modal.msgError(this.errorMsg(error));
|
||||
});
|
||||
} else {
|
||||
|
||||
editSampleDataAPI(params).then(res => {
|
||||
this.loading.close();
|
||||
if (res.code === 200) {
|
||||
this.handleReuslt(res);
|
||||
} else {
|
||||
this.$modal.msgError(res.msg);
|
||||
}
|
||||
}).catch(error => {
|
||||
this.loading.close();
|
||||
this.$modal.msgError(this.errorMsg(error));
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
}
|
||||
};
|
||||
</script>
|
||||
<style lang="scss" scoped>
|
||||
.w700 ::v-deep .el-dialog {
|
||||
width: 700px;
|
||||
font-family: Source Han Sans CN, Source Han Sans CN;
|
||||
}
|
||||
|
||||
.w500 ::v-deep .el-dialog {
|
||||
width: 500px;
|
||||
font-family: Source Han Sans CN, Source Han Sans CN;
|
||||
}
|
||||
|
||||
.w500 ::v-deep .el-dialog__header,
|
||||
.w700 ::v-deep .el-dialog__header {
|
||||
.el-dialog__title {
|
||||
font-size: 16px;
|
||||
}
|
||||
}
|
||||
|
||||
.yxq .el-range-separator {
|
||||
margin-right: 7px !important;
|
||||
}
|
||||
|
||||
.el-date-editor--daterange.el-input__inner {
|
||||
width: 260px;
|
||||
}
|
||||
|
||||
.form-item {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.select-style {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
}
|
||||
|
||||
.confirm-btn {
|
||||
width: 98px;
|
||||
height: 36px;
|
||||
background: #1F72EA;
|
||||
box-shadow: 0px 4px 8px 0px rgba(51, 135, 255, 0.5);
|
||||
border-radius: 4px 4px 4px 4px;
|
||||
color: #fff;
|
||||
border: none;
|
||||
font-size: 14px;
|
||||
transition: all 0.3s;
|
||||
|
||||
&:hover {
|
||||
background: #4A8BFF;
|
||||
box-shadow: 0px 6px 12px 0px rgba(51, 135, 255, 0.6);
|
||||
}
|
||||
}
|
||||
|
||||
.cancel-btn {
|
||||
width: 98px;
|
||||
height: 36px;
|
||||
background: #E5E5E5;
|
||||
box-shadow: 0px 4px 8px 0px rgba(76, 76, 76, 0.2);
|
||||
border-radius: 4px 4px 4px 4px;
|
||||
color: #333;
|
||||
border: none;
|
||||
font-size: 14px;
|
||||
transition: all 0.3s;
|
||||
|
||||
&:hover {
|
||||
background: #d0d0d0;
|
||||
box-shadow: 0px 6px 12px 0px rgba(76, 76, 76, 0.3);
|
||||
}
|
||||
}
|
||||
|
||||
::v-deep .el-dialog__footer {
|
||||
text-align: center;
|
||||
}
|
||||
</style>
|
||||
|
|
@ -0,0 +1,19 @@
|
|||
export const formLabel = [
|
||||
{
|
||||
isShow: false, // 是否展示label
|
||||
f_type: 'ipt',
|
||||
f_label: '样本库名称',
|
||||
f_model: 'proName',
|
||||
f_max: 32,
|
||||
f_width: '250px',
|
||||
},
|
||||
]
|
||||
|
||||
export const columnsList = [
|
||||
{ t_props: 'sampleLibraryName', t_label: '样本库名称' },
|
||||
{ t_props: 'sampleLibraryLabel', t_label: '样本标签' },
|
||||
{ t_props: 'sampleLibraryType', t_label: '数据类型' },
|
||||
{ t_slot: 'sampleLibraryNum', t_label: '数据量' },
|
||||
{ t_props: 'sampleLibraryDesc', t_label: '描述' },
|
||||
{ t_props: 'updateTime', t_label: '更新时间' },
|
||||
]
|
||||
|
|
@ -0,0 +1,154 @@
|
|||
<template>
|
||||
<!-- 样本库管理 -->
|
||||
<el-card class="sample-container">
|
||||
<div class="table-container">
|
||||
<TableModel :formLabel="formLabel" :showOperation="true" :showRightTools="false" ref="sampleTableRef"
|
||||
:columnsList="columnsList" :request-api="sampleListAPI" :handleColWidth="250">
|
||||
<template slot="tableTitle">
|
||||
<h3>数据列表</h3>
|
||||
</template>
|
||||
<template slot="tableActions">
|
||||
<el-button @click="handleAdd" v-hasPermi="['data:sample:add']" class="add-btn"><i
|
||||
class="el-icon-plus"></i> 新建样本库</el-button>
|
||||
</template>
|
||||
|
||||
<template slot="sampleLibraryNum" slot-scope="{ data }">
|
||||
<span>{{ data.sampleLibraryNum }}</span>
|
||||
</template>
|
||||
<template slot="handle" slot-scope="{ data }">
|
||||
<el-button type="text" v-hasPermi="['data:sample:import']" class="action-btn"
|
||||
style="color: #1f72ea" @click="handleImport(data)">
|
||||
导入
|
||||
</el-button>
|
||||
<el-button type="text" v-hasPermi="['data:sample:del']" class="action-btn"
|
||||
style="color: #EAA819" @click="handleUpdate(data)">
|
||||
修改
|
||||
</el-button>
|
||||
<el-button type="text" v-hasPermi="['data:sample:del']" class="action-btn"
|
||||
style="color: #DB3E29" @click="handleDelete(data)">
|
||||
删除
|
||||
</el-button>
|
||||
</template>
|
||||
</TableModel>
|
||||
</div>
|
||||
<!-- 新建样本库 -->
|
||||
<SampleForm v-if="showSampleForm" :title="title" :rowData="row" :isAdd="isAdd" @closeDialog="showSampleForm = false"
|
||||
:width="600" @handleQuery="handleQuery" />
|
||||
</el-card>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import TableModel from '@/components/TableModel2'
|
||||
import { columnsList, formLabel } from './config'
|
||||
import { sampleListAPI,delSampleDataAPI } from '@/api/data/sample'
|
||||
import SampleForm from './components/SampleForm.vue'
|
||||
export default {
|
||||
name: 'Sample',
|
||||
components: {
|
||||
TableModel,
|
||||
SampleForm,
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
formLabel,
|
||||
columnsList,
|
||||
sampleListAPI,
|
||||
showSampleForm: false,
|
||||
title: '',
|
||||
row: {},
|
||||
}
|
||||
},
|
||||
|
||||
created() { },
|
||||
|
||||
methods: {
|
||||
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.title = '新建样本库'
|
||||
this.isAdd = 'add'
|
||||
this.showSampleForm = true
|
||||
},
|
||||
|
||||
/** 修改操作 */
|
||||
handleUpdate(row) {
|
||||
this.title = '修改样本库'
|
||||
this.isAdd = 'edit'
|
||||
this.row = row
|
||||
this.showSampleForm = true
|
||||
},
|
||||
|
||||
|
||||
/* 搜索操作 */
|
||||
handleQuery() {
|
||||
this.$refs.sampleTableRef.getTableList()
|
||||
},
|
||||
|
||||
/** 删除操作 */
|
||||
handleDelete(row) {
|
||||
this.$confirm(
|
||||
`确定要删除"${row.sampleLibraryName}"吗?删除后将无法恢复!`,
|
||||
'操作提示',
|
||||
{
|
||||
confirmButtonText: '确定',
|
||||
cancelButtonText: '取消',
|
||||
type: 'warning',
|
||||
dangerouslyUseHTMLString: true,
|
||||
customClass: 'delete-confirm-dialog',
|
||||
},
|
||||
).then(() => {
|
||||
delSampleDataAPI({
|
||||
sampleLibraryId: row.sampleLibraryId,
|
||||
})
|
||||
.then((res) => {
|
||||
if (res.code === 200) {
|
||||
this.$message.success('删除成功')
|
||||
this.handleQuery()
|
||||
} else {
|
||||
this.$message.error(res.msg || '删除失败')
|
||||
}
|
||||
})
|
||||
.catch((error) => {
|
||||
console.error('删除失败:', error)
|
||||
})
|
||||
})
|
||||
},
|
||||
},
|
||||
}
|
||||
</script>
|
||||
<style scoped lang="scss">
|
||||
.sample-container {
|
||||
height: calc(100vh - 84px);
|
||||
overflow: hidden;
|
||||
background: linear-gradient(180deg, #f1f6ff 20%, #e5efff 100%);
|
||||
}
|
||||
|
||||
::v-deep .table-card {
|
||||
height: calc(100vh - 230px) !important;
|
||||
}
|
||||
|
||||
.add-btn {
|
||||
width: 121px;
|
||||
height: 36px;
|
||||
background: #1f72ea;
|
||||
box-shadow: 0px 4px 8px 0px rgba(51, 135, 255, 0.5);
|
||||
border-radius: 4px 4px 4px 4px;
|
||||
color: #fff;
|
||||
border: none;
|
||||
font-size: 14px;
|
||||
transition: all 0.3s;
|
||||
|
||||
&:hover {
|
||||
background: #4a8bff;
|
||||
box-shadow: 0px 6px 12px 0px rgba(51, 135, 255, 0.6);
|
||||
}
|
||||
}
|
||||
|
||||
.action-btn {
|
||||
margin-right: 8px;
|
||||
|
||||
&:last-child {
|
||||
margin-right: 0;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
Loading…
Reference in New Issue