2025-07-18 17:22:56 +08:00
|
|
|
|
<template>
|
2025-11-15 16:39:05 +08:00
|
|
|
|
<div class="raw-material-selector">
|
|
|
|
|
|
<!-- 触发器按钮 -->
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<div class="el-input" v-if="!readonly" type="text" @click="dialogVisible = true">
|
|
|
|
|
|
<div class="el-input__inner">
|
|
|
|
|
|
<el-icon class="el-icon-search"></el-icon>
|
|
|
|
|
|
{{ buttonText }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
2025-11-15 16:39:05 +08:00
|
|
|
|
<span v-else class="readonly-text">{{ displayText }}</span>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 选择对话框 -->
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<el-dialog title="选择原材料" :visible.sync="dialogVisible" width="1200px" :close-on-click-modal="false"
|
|
|
|
|
|
@close="handleClose" append-to-body>
|
2025-11-17 16:24:28 +08:00
|
|
|
|
<!-- 搜索区域(保持不变) -->
|
2025-11-15 16:39:05 +08:00
|
|
|
|
<el-form :inline="true" :model="queryParams" class="search-form" size="small">
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<el-form-item label="编号">
|
|
|
|
|
|
<el-input v-model="queryParams.rawMaterialCode" placeholder="请输入原材料编号" clearable
|
|
|
|
|
|
@keyup.enter.native="handleQuery" />
|
2025-11-15 16:39:05 +08:00
|
|
|
|
</el-form-item>
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<el-form-item label="名称">
|
2025-11-28 13:12:13 +08:00
|
|
|
|
<MemoInput storageKey="productName" v-model="queryParams.rawMaterialName" placeholder="请输入原材料名称" clearable
|
2025-11-20 11:27:47 +08:00
|
|
|
|
@keyup.enter.native="handleQuery" />
|
2025-11-15 16:39:05 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="规格">
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<el-input v-model="queryParams.specification" placeholder="请输入规格" clearable
|
|
|
|
|
|
@keyup.enter.native="handleQuery" />
|
2025-11-15 16:39:05 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="材质">
|
2025-11-28 11:02:19 +08:00
|
|
|
|
<MemoInput storageKey="material" v-model="queryParams.material" placeholder="请输入材质" @keyup.enter.native="handleQuery" />
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="厂家">
|
|
|
|
|
|
<MemoInput storageKey="manufacturer" v-model="queryParams.manufacturer" placeholder="请输入厂家" @keyup.enter.native="handleQuery" />
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="表面处理">
|
|
|
|
|
|
<MemoInput storageKey="surfaceTreatmentDesc" v-model="queryParams.surfaceTreatmentDesc" placeholder="请输入表面处理" @keyup.enter.native="handleQuery" />
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="锌层">
|
|
|
|
|
|
<MemoInput storageKey="zincLayer" v-model="queryParams.zincLayer" placeholder="请输入锌层" @keyup.enter.native="handleQuery" />
|
2025-11-15 16:39:05 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item>
|
|
|
|
|
|
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
|
|
|
|
|
|
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
|
|
|
|
|
|
</el-form-item>
|
2025-08-19 15:39:59 +08:00
|
|
|
|
</el-form>
|
|
|
|
|
|
|
2025-11-17 16:24:28 +08:00
|
|
|
|
<!-- 卡片布局(替换原表格) -->
|
|
|
|
|
|
<div v-loading="loading" class="card-container">
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<div v-for="(item, index) in rawMaterialList" :key="index + item.rawMaterialId" class="material-card"
|
|
|
|
|
|
:class="{ 'selected-card': isSelected(item.rawMaterialId) }" @click="handleRowClick(item)">
|
2025-11-17 16:24:28 +08:00
|
|
|
|
<!-- 多选勾选框 -->
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<el-checkbox v-if="multiple" :checked="isSelected(item.rawMaterialId)"
|
|
|
|
|
|
@change="(val) => handleCardSelection(val, item)" class="card-checkbox" />
|
|
|
|
|
|
|
2025-11-17 16:24:28 +08:00
|
|
|
|
<!-- 卡片内容(包含所有原表格字段) -->
|
|
|
|
|
|
<div class="card-content">
|
|
|
|
|
|
<div class="card-title">
|
|
|
|
|
|
<span class="name">{{ item.rawMaterialName }}</span>
|
|
|
|
|
|
<span class="code">[{{ item.rawMaterialCode }}]</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="card-info">
|
|
|
|
|
|
<div class="info-item">规格:<span>{{ item.specification || '-' }}</span></div>
|
|
|
|
|
|
<div class="info-item">单位:<span>{{ item.unit || '-' }}</span></div>
|
|
|
|
|
|
<div class="info-item">材质:<span>{{ item.material || '-' }}</span></div>
|
|
|
|
|
|
<div class="info-item">厂家:<span>{{ item.manufacturer || '-' }}</span></div>
|
|
|
|
|
|
<div class="info-item">表面处理:<span>{{ item.surfaceTreatmentDesc || '-' }}</span></div>
|
|
|
|
|
|
<div class="info-item">锌层:<span>{{ item.zincLayer || '-' }}</span></div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
2025-11-20 11:27:47 +08:00
|
|
|
|
|
2025-11-17 16:24:28 +08:00
|
|
|
|
<!-- 空数据提示 -->
|
|
|
|
|
|
<div class="empty-tip" v-if="rawMaterialList.length === 0 && !loading">
|
|
|
|
|
|
暂无匹配的原材料数据
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 分页(保持不变) -->
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
|
|
|
|
|
|
@pagination="getList" />
|
2025-08-19 15:39:59 +08:00
|
|
|
|
|
2025-11-15 16:39:05 +08:00
|
|
|
|
<div slot="footer" class="dialog-footer">
|
|
|
|
|
|
<el-button @click="dialogVisible = false">取消</el-button>
|
2025-11-20 11:27:47 +08:00
|
|
|
|
<el-button type="primary" @click="confirmSelection" v-if="multiple">
|
2025-11-15 16:39:05 +08:00
|
|
|
|
确认选择
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
</div>
|
2025-07-18 17:22:56 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
2025-11-15 16:39:05 +08:00
|
|
|
|
import { listRawMaterial } from '@/api/wms/rawMaterial';
|
2025-11-28 11:02:19 +08:00
|
|
|
|
import MemoInput from '@/components/MemoInput/index.vue'
|
2025-07-21 11:55:04 +08:00
|
|
|
|
|
2025-07-18 17:22:56 +08:00
|
|
|
|
export default {
|
2025-11-15 16:39:05 +08:00
|
|
|
|
name: 'RawMaterialSelector',
|
2025-11-28 11:02:19 +08:00
|
|
|
|
components: {
|
|
|
|
|
|
MemoInput
|
|
|
|
|
|
},
|
2025-07-18 17:22:56 +08:00
|
|
|
|
props: {
|
2025-11-15 16:39:05 +08:00
|
|
|
|
value: {
|
2025-07-18 17:22:56 +08:00
|
|
|
|
type: String,
|
2025-11-15 16:39:05 +08:00
|
|
|
|
default: ''
|
2025-08-19 15:39:59 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
readonly: {
|
2025-08-19 15:39:59 +08:00
|
|
|
|
type: Boolean,
|
|
|
|
|
|
default: false
|
2025-11-01 13:02:42 +08:00
|
|
|
|
},
|
|
|
|
|
|
multiple: {
|
2025-11-15 16:39:05 +08:00
|
|
|
|
type: Boolean,
|
|
|
|
|
|
default: false
|
2025-11-01 13:02:42 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
filters: {
|
|
|
|
|
|
type: Object,
|
|
|
|
|
|
default: () => ({})
|
|
|
|
|
|
}
|
2025-08-19 16:11:28 +08:00
|
|
|
|
},
|
2025-07-18 17:22:56 +08:00
|
|
|
|
data() {
|
|
|
|
|
|
return {
|
2025-11-15 16:39:05 +08:00
|
|
|
|
dialogVisible: false,
|
2025-08-19 15:39:59 +08:00
|
|
|
|
loading: false,
|
2025-11-17 16:24:28 +08:00
|
|
|
|
rawMaterialList: [],
|
2025-11-15 16:39:05 +08:00
|
|
|
|
total: 0,
|
|
|
|
|
|
queryParams: {
|
|
|
|
|
|
pageNum: 1,
|
|
|
|
|
|
pageSize: 10,
|
2025-08-19 16:11:28 +08:00
|
|
|
|
rawMaterialCode: undefined,
|
|
|
|
|
|
rawMaterialName: undefined,
|
2025-11-15 16:39:05 +08:00
|
|
|
|
specification: undefined,
|
|
|
|
|
|
material: undefined,
|
|
|
|
|
|
manufacturer: undefined,
|
|
|
|
|
|
surfaceTreatmentDesc: undefined,
|
|
|
|
|
|
zincLayer: undefined
|
2025-08-19 15:39:59 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
selectedIds: [],
|
|
|
|
|
|
selectedRows: []
|
2025-07-18 17:22:56 +08:00
|
|
|
|
};
|
|
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
computed: {
|
|
|
|
|
|
buttonText() {
|
2025-11-20 11:27:47 +08:00
|
|
|
|
// 如果为选中任何原材料,显示选择原材料
|
|
|
|
|
|
// 如果为选中多个原材料,显示已选 X 项
|
|
|
|
|
|
// 如果为选中单个原材料,显示原材料名称
|
2025-11-20 15:53:45 +08:00
|
|
|
|
console.log(this.selectedIds);
|
2025-11-20 11:27:47 +08:00
|
|
|
|
if (this.selectedIds.length === 0) {
|
|
|
|
|
|
return '请选择原材料';
|
|
|
|
|
|
}
|
2025-11-01 13:02:42 +08:00
|
|
|
|
if (this.multiple) {
|
2025-11-20 11:27:47 +08:00
|
|
|
|
return `已选 ${this.selectedIds.length} 项`;
|
2025-11-01 13:02:42 +08:00
|
|
|
|
} else {
|
2025-11-20 11:27:47 +08:00
|
|
|
|
return `${this.selectedRows[0]?.rawMaterialName}[${this.selectedRows[0]?.specification || '-'}] (${this.selectedRows[0]?.material || '-'})`;
|
2025-11-01 13:02:42 +08:00
|
|
|
|
}
|
2025-07-21 10:56:50 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
displayText() {
|
2025-11-01 13:02:42 +08:00
|
|
|
|
if (this.multiple) {
|
2025-11-20 11:27:47 +08:00
|
|
|
|
return this.selectedIds.length > 0
|
|
|
|
|
|
? `已选 ${this.selectedIds.length} 项`
|
2025-11-15 16:39:05 +08:00
|
|
|
|
: '未选择';
|
2025-11-01 13:02:42 +08:00
|
|
|
|
} else {
|
2025-11-15 16:39:05 +08:00
|
|
|
|
return this.selectedRows[0]?.rawMaterialName || '未选择';
|
2025-11-01 13:02:42 +08:00
|
|
|
|
}
|
2025-11-20 15:53:45 +08:00
|
|
|
|
},
|
|
|
|
|
|
|
2025-07-18 17:22:56 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
watch: {
|
|
|
|
|
|
value: {
|
|
|
|
|
|
immediate: true,
|
|
|
|
|
|
handler(val) {
|
2025-11-20 15:53:45 +08:00
|
|
|
|
console.log('watch触发val', val);
|
2025-11-15 16:39:05 +08:00
|
|
|
|
this.selectedIds = val ? val.split(',').filter(id => id) : [];
|
2025-11-17 16:24:28 +08:00
|
|
|
|
// this.syncSelectedRows();
|
|
|
|
|
|
this.$forceUpdate(); // 新增:强制刷新视图
|
2025-11-15 16:39:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
dialogVisible(val) {
|
|
|
|
|
|
if (val) {
|
2025-11-17 16:24:28 +08:00
|
|
|
|
this.getList();
|
2025-11-15 16:39:05 +08:00
|
|
|
|
}
|
2025-08-23 17:22:06 +08:00
|
|
|
|
}
|
2025-07-30 10:53:06 +08:00
|
|
|
|
},
|
2025-07-18 17:22:56 +08:00
|
|
|
|
methods: {
|
2025-11-17 16:24:28 +08:00
|
|
|
|
// 判断卡片是否选中
|
|
|
|
|
|
isSelected(rawMaterialId) {
|
|
|
|
|
|
return this.selectedIds.includes(rawMaterialId);
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 卡片选择事件(多选)
|
|
|
|
|
|
handleCardSelection(checked, item) {
|
|
|
|
|
|
if (checked) {
|
|
|
|
|
|
!this.selectedIds.includes(item.rawMaterialId) && this.selectedIds.push(item.rawMaterialId);
|
|
|
|
|
|
} else {
|
2025-11-20 15:53:45 +08:00
|
|
|
|
this.selectedIds = this.selectedIds.filter(id => id != item.rawMaterialId);
|
2025-11-17 16:24:28 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 原有方法保持不变(仅修改同步选中状态逻辑)
|
2025-11-15 16:39:05 +08:00
|
|
|
|
async getList() {
|
|
|
|
|
|
try {
|
|
|
|
|
|
this.loading = true;
|
|
|
|
|
|
const params = { ...this.queryParams, ...this.filters };
|
2025-11-24 17:21:26 +08:00
|
|
|
|
console.log('params', params);
|
2025-11-15 16:39:05 +08:00
|
|
|
|
const response = await listRawMaterial(params);
|
|
|
|
|
|
if (response.code === 200) {
|
2025-11-20 15:53:45 +08:00
|
|
|
|
this.rawMaterialList = response.rows.map(item => ({
|
|
|
|
|
|
...item,
|
|
|
|
|
|
rawMaterialId: item.rawMaterialId.toString()
|
|
|
|
|
|
})) || [];
|
2025-11-15 16:39:05 +08:00
|
|
|
|
this.total = response.total || 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
return this.rawMaterialList;
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
console.error('获取原材料列表失败', error);
|
|
|
|
|
|
this.$message.error('获取原材料列表失败');
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
this.loading = false;
|
2025-11-04 16:45:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
|
|
|
|
|
|
handleQuery() {
|
|
|
|
|
|
this.queryParams.pageNum = 1;
|
2025-11-17 16:24:28 +08:00
|
|
|
|
this.getList();
|
2025-10-31 16:20:03 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
|
|
|
|
|
|
resetQuery() {
|
|
|
|
|
|
this.queryParams = {
|
|
|
|
|
|
pageNum: 1,
|
|
|
|
|
|
pageSize: 10,
|
2025-08-19 16:11:28 +08:00
|
|
|
|
rawMaterialCode: undefined,
|
|
|
|
|
|
rawMaterialName: undefined,
|
2025-11-15 16:39:05 +08:00
|
|
|
|
specification: undefined,
|
|
|
|
|
|
material: undefined,
|
|
|
|
|
|
manufacturer: undefined,
|
|
|
|
|
|
surfaceTreatmentDesc: undefined,
|
|
|
|
|
|
zincLayer: undefined
|
2025-08-19 15:39:59 +08:00
|
|
|
|
};
|
2025-11-17 16:24:28 +08:00
|
|
|
|
this.getList();
|
2025-08-19 15:39:59 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
|
|
|
|
|
|
handleRowClick(row) {
|
|
|
|
|
|
if (!this.multiple) {
|
|
|
|
|
|
this.selectedIds = [row.rawMaterialId];
|
|
|
|
|
|
this.selectedRows = [row];
|
|
|
|
|
|
this.confirmSelection();
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
handleSelect(row) {
|
|
|
|
|
|
if (this.multiple) {
|
|
|
|
|
|
const index = this.selectedIds.indexOf(row.rawMaterialId);
|
2025-11-20 11:27:47 +08:00
|
|
|
|
index > -1
|
2025-11-15 16:39:05 +08:00
|
|
|
|
? (this.selectedIds.splice(index, 1), this.selectedRows.splice(index, 1))
|
|
|
|
|
|
: (this.selectedIds.push(row.rawMaterialId), this.selectedRows.push(row));
|
|
|
|
|
|
} else {
|
|
|
|
|
|
this.selectedIds = [row.rawMaterialId];
|
|
|
|
|
|
this.selectedRows = [row];
|
|
|
|
|
|
this.confirmSelection();
|
|
|
|
|
|
}
|
2025-08-19 15:39:59 +08:00
|
|
|
|
},
|
2025-11-15 16:39:05 +08:00
|
|
|
|
|
|
|
|
|
|
confirmSelection() {
|
|
|
|
|
|
const emitValue = this.selectedIds.join(',');
|
|
|
|
|
|
this.$emit('input', emitValue);
|
|
|
|
|
|
this.$emit('change', emitValue, this.selectedRows);
|
|
|
|
|
|
this.dialogVisible = false;
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
handleClose() {
|
|
|
|
|
|
this.selectedIds = this.value ? this.value.split(',').filter(id => id) : [];
|
2025-11-17 16:24:28 +08:00
|
|
|
|
// this.syncSelectedRows();
|
2025-11-15 16:39:05 +08:00
|
|
|
|
this.dialogVisible = false;
|
2025-08-19 15:39:59 +08:00
|
|
|
|
}
|
2025-07-18 17:22:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
</script>
|
2025-07-21 10:56:50 +08:00
|
|
|
|
|
2025-11-15 16:39:05 +08:00
|
|
|
|
<style scoped lang="scss">
|
|
|
|
|
|
.raw-material-selector {
|
|
|
|
|
|
display: inline-block;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.search-form {
|
|
|
|
|
|
margin-bottom: 20px;
|
2025-11-17 16:24:28 +08:00
|
|
|
|
flex-wrap: wrap;
|
2025-11-15 16:39:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.readonly-text {
|
|
|
|
|
|
color: #606266;
|
|
|
|
|
|
line-height: 1;
|
|
|
|
|
|
padding: 8px 0;
|
|
|
|
|
|
display: inline-block;
|
2025-07-21 10:56:50 +08:00
|
|
|
|
}
|
2025-08-19 15:39:59 +08:00
|
|
|
|
|
2025-11-15 16:39:05 +08:00
|
|
|
|
::v-deep .el-dialog__body {
|
|
|
|
|
|
padding: 20px;
|
2025-11-17 16:24:28 +08:00
|
|
|
|
overflow-x: auto;
|
2025-07-21 10:56:50 +08:00
|
|
|
|
}
|
2025-08-19 15:39:59 +08:00
|
|
|
|
|
2025-11-15 16:39:05 +08:00
|
|
|
|
::v-deep .el-form-item {
|
|
|
|
|
|
margin-bottom: 15px;
|
|
|
|
|
|
margin-right: 15px;
|
2025-07-21 10:56:50 +08:00
|
|
|
|
}
|
2025-11-17 16:24:28 +08:00
|
|
|
|
|
|
|
|
|
|
/* 卡片容器样式 */
|
|
|
|
|
|
.card-container {
|
|
|
|
|
|
display: grid;
|
|
|
|
|
|
grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
|
|
|
|
|
|
gap: 20px;
|
|
|
|
|
|
margin-bottom: 20px;
|
|
|
|
|
|
min-height: 400px;
|
|
|
|
|
|
padding: 10px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 卡片样式 */
|
|
|
|
|
|
.material-card {
|
|
|
|
|
|
border: 1px solid #e6e6e6;
|
2025-11-20 11:27:47 +08:00
|
|
|
|
border-radius: 0px;
|
|
|
|
|
|
padding: 4px;
|
2025-11-17 16:24:28 +08:00
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
transition: all 0.3s ease;
|
|
|
|
|
|
position: relative;
|
|
|
|
|
|
background: #fff;
|
|
|
|
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
|
|
border-color: #409eff;
|
|
|
|
|
|
box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.08);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 选中卡片样式 */
|
|
|
|
|
|
.selected-card {
|
|
|
|
|
|
border-color: #409eff;
|
|
|
|
|
|
background-color: #f0f7ff;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 多选勾选框位置 */
|
|
|
|
|
|
.card-checkbox {
|
|
|
|
|
|
position: absolute;
|
|
|
|
|
|
top: 16px;
|
|
|
|
|
|
right: 16px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 卡片内容样式 */
|
|
|
|
|
|
.card-content {
|
2025-11-20 11:27:47 +08:00
|
|
|
|
margin-right: 24px;
|
|
|
|
|
|
/* 给多选框留空间 */
|
2025-11-17 16:24:28 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.card-title {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
margin-bottom: 12px;
|
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.name {
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
color: #1989fa;
|
|
|
|
|
|
margin-right: 8px;
|
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.code {
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
color: #909399;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.card-info {
|
|
|
|
|
|
display: grid;
|
|
|
|
|
|
grid-template-columns: 1fr 1fr;
|
|
|
|
|
|
gap: 8px;
|
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
|
color: #606266;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.info-item {
|
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.info-item span {
|
|
|
|
|
|
color: #303133;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* 空数据提示 */
|
|
|
|
|
|
.empty-tip {
|
|
|
|
|
|
grid-column: 1 / -1;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: center;
|
|
|
|
|
|
height: 400px;
|
|
|
|
|
|
color: #909399;
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
}
|
2025-11-15 16:39:05 +08:00
|
|
|
|
</style>
|