|
@@ -4,15 +4,15 @@
|
|
<template #header>
|
|
<template #header>
|
|
<div class="report-header">
|
|
<div class="report-header">
|
|
<div class="header-content">
|
|
<div class="header-content">
|
|
- <h2 class="report-title">维度管理</h2>
|
|
|
|
- <p class="report-subtitle">管理数据报表的维度配置</p>
|
|
|
|
|
|
+ <h2 class="report-title">{{ t('dataReport.dimensionManagement') }}</h2>
|
|
|
|
+ <p class="report-subtitle">{{ t('dataReport.manageDimensionConfig') }}</p>
|
|
</div>
|
|
</div>
|
|
<div class="header-actions">
|
|
<div class="header-actions">
|
|
<el-button type="primary" @click="handleAdd" :icon="Plus">
|
|
<el-button type="primary" @click="handleAdd" :icon="Plus">
|
|
- 新增维度
|
|
|
|
|
|
+ {{ t('dataReport.addDimension') }}
|
|
</el-button>
|
|
</el-button>
|
|
<el-button @click="refreshList" :icon="Refresh" class="sa-button-refresh">
|
|
<el-button @click="refreshList" :icon="Refresh" class="sa-button-refresh">
|
|
- 刷新
|
|
|
|
|
|
+ {{ t('dataReport.refreshData') }}
|
|
</el-button>
|
|
</el-button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
@@ -22,7 +22,7 @@
|
|
<div class="search-section">
|
|
<div class="search-section">
|
|
<el-form :model="searchForm" inline class="search-form">
|
|
<el-form :model="searchForm" inline class="search-form">
|
|
<el-form-item>
|
|
<el-form-item>
|
|
- <el-input v-model="searchForm.keyword" placeholder="请输入维度名称或编码" clearable
|
|
|
|
|
|
+ <el-input v-model="searchForm.keyword" :placeholder="t('dataReport.enterDimensionNameOrCode')" clearable
|
|
@keyup.enter="handleSearch" class="search-input">
|
|
@keyup.enter="handleSearch" class="search-input">
|
|
<template #prefix>
|
|
<template #prefix>
|
|
<el-icon>
|
|
<el-icon>
|
|
@@ -33,10 +33,10 @@
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item>
|
|
<el-form-item>
|
|
<el-button type="primary" @click="handleSearch" :icon="Search">
|
|
<el-button type="primary" @click="handleSearch" :icon="Search">
|
|
- 搜索
|
|
|
|
|
|
+ {{ t('common.search') }}
|
|
</el-button>
|
|
</el-button>
|
|
<el-button @click="handleReset" :icon="RefreshLeft">
|
|
<el-button @click="handleReset" :icon="RefreshLeft">
|
|
- 重置
|
|
|
|
|
|
+ {{ t('common.reset') }}
|
|
</el-button>
|
|
</el-button>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
</el-form>
|
|
</el-form>
|
|
@@ -48,7 +48,7 @@
|
|
@selection-change="handleSelectionChange">
|
|
@selection-change="handleSelectionChange">
|
|
<el-table-column type="selection" width="55" />
|
|
<el-table-column type="selection" width="55" />
|
|
<el-table-column prop="id" label="ID" width="80" />
|
|
<el-table-column prop="id" label="ID" width="80" />
|
|
- <el-table-column prop="name" label="维度名称" min-width="150">
|
|
|
|
|
|
+ <el-table-column prop="name" :label="t('dataReport.dimensionName')" min-width="150">
|
|
<template #default="{ row }">
|
|
<template #default="{ row }">
|
|
<div class="dimension-name">
|
|
<div class="dimension-name">
|
|
<el-tag :type="getDimensionTypeTag(row.type)" size="small" style="margin-right: 8px;">
|
|
<el-tag :type="getDimensionTypeTag(row.type)" size="small" style="margin-right: 8px;">
|
|
@@ -58,40 +58,40 @@
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column prop="code" label="维度编码" width="120" />
|
|
|
|
- <el-table-column prop="description" label="描述" min-width="200" show-overflow-tooltip />
|
|
|
|
- <el-table-column prop="dataType" label="数据类型" width="100">
|
|
|
|
|
|
+ <el-table-column prop="code" :label="t('dataReport.dimensionCode')" width="120" />
|
|
|
|
+ <el-table-column prop="description" :label="t('form.description')" min-width="200" show-overflow-tooltip />
|
|
|
|
+ <el-table-column prop="dataType" :label="t('dataReport.dataType')" width="100">
|
|
<template #default="{ row }">
|
|
<template #default="{ row }">
|
|
<el-tag size="small" :type="getDataTypeTag(row.dataType)">
|
|
<el-tag size="small" :type="getDataTypeTag(row.dataType)">
|
|
{{ getDataTypeLabel(row.dataType) }}
|
|
{{ getDataTypeLabel(row.dataType) }}
|
|
</el-tag>
|
|
</el-tag>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column prop="unit" label="单位" width="80" />
|
|
|
|
- <el-table-column prop="status" label="状态" width="80">
|
|
|
|
|
|
+ <el-table-column prop="unit" :label="t('dataReport.unit')" width="80" />
|
|
|
|
+ <el-table-column prop="status" :label="t('common.status')" width="80">
|
|
<template #default="{ row }">
|
|
<template #default="{ row }">
|
|
<el-switch v-model="row.status" :active-value="1" :inactive-value="0" @change="handleStatusChange(row)" />
|
|
<el-switch v-model="row.status" :active-value="1" :inactive-value="0" @change="handleStatusChange(row)" />
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column prop="createTime" label="创建时间" width="160">
|
|
|
|
|
|
+ <el-table-column prop="createTime" :label="t('form.createTime')" width="160">
|
|
<template #default="{ row }">
|
|
<template #default="{ row }">
|
|
{{ formatDate(row.createTime) }}
|
|
{{ formatDate(row.createTime) }}
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
- <el-table-column label="操作" width="180" fixed="right">
|
|
|
|
|
|
+ <el-table-column :label="t('common.operation')" width="180" fixed="right">
|
|
<template #default="{ row }">
|
|
<template #default="{ row }">
|
|
<el-button size="small" type="primary" link @click="handleEdit(row)">
|
|
<el-button size="small" type="primary" link @click="handleEdit(row)">
|
|
<el-icon>
|
|
<el-icon>
|
|
<Edit />
|
|
<Edit />
|
|
</el-icon>
|
|
</el-icon>
|
|
- 编辑
|
|
|
|
|
|
+ {{ t('common.edit') }}
|
|
</el-button>
|
|
</el-button>
|
|
|
|
|
|
<el-button size="small" type="danger" link @click="handleDelete(row)">
|
|
<el-button size="small" type="danger" link @click="handleDelete(row)">
|
|
<el-icon>
|
|
<el-icon>
|
|
<Delete />
|
|
<Delete />
|
|
</el-icon>
|
|
</el-icon>
|
|
- 删除
|
|
|
|
|
|
+ {{ t('common.delete') }}
|
|
</el-button>
|
|
</el-button>
|
|
</template>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table-column>
|
|
@@ -100,17 +100,17 @@
|
|
<!-- 批量操作 -->
|
|
<!-- 批量操作 -->
|
|
<div class="batch-actions" v-if="selectedRows.length > 0">
|
|
<div class="batch-actions" v-if="selectedRows.length > 0">
|
|
<span class="batch-info">
|
|
<span class="batch-info">
|
|
- 已选择 {{ selectedRows.length }} 项
|
|
|
|
|
|
+ {{ t('dataReport.selectedItems', { count: selectedRows.length }) }}
|
|
</span>
|
|
</span>
|
|
<div class="batch-buttons">
|
|
<div class="batch-buttons">
|
|
<el-button type="danger" size="small" @click="handleBatchDelete">
|
|
<el-button type="danger" size="small" @click="handleBatchDelete">
|
|
- 批量删除
|
|
|
|
|
|
+ {{ t('dataReport.batchDelete') }}
|
|
</el-button>
|
|
</el-button>
|
|
<el-button type="success" size="small" @click="handleBatchEnable">
|
|
<el-button type="success" size="small" @click="handleBatchEnable">
|
|
- 批量启用
|
|
|
|
|
|
+ {{ t('dataReport.batchEnable') }}
|
|
</el-button>
|
|
</el-button>
|
|
<el-button type="warning" size="small" @click="handleBatchDisable">
|
|
<el-button type="warning" size="small" @click="handleBatchDisable">
|
|
- 批量禁用
|
|
|
|
|
|
+ {{ t('dataReport.batchDisable') }}
|
|
</el-button>
|
|
</el-button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
@@ -135,9 +135,13 @@ import {
|
|
Plus, Refresh, Search, RefreshLeft, Edit, Delete,
|
|
Plus, Refresh, Search, RefreshLeft, Edit, Delete,
|
|
Check, Close
|
|
Check, Close
|
|
} from '@element-plus/icons-vue'
|
|
} from '@element-plus/icons-vue'
|
|
|
|
+import { useI18n } from 'vue-i18n'
|
|
import { api } from '../../data.service.js'
|
|
import { api } from '../../data.service.js'
|
|
import { useModal } from '@/sheep/components/sa-modal/sa-modal.vue'
|
|
import { useModal } from '@/sheep/components/sa-modal/sa-modal.vue'
|
|
|
|
|
|
|
|
+// 使用国际化
|
|
|
|
+const { t } = useI18n();
|
|
|
|
+
|
|
// 响应式数据
|
|
// 响应式数据
|
|
const loading = ref(false)
|
|
const loading = ref(false)
|
|
const selectedRows = ref([])
|
|
const selectedRows = ref([])
|
|
@@ -220,7 +224,7 @@ const handleAdd = () => {
|
|
width: '600px',
|
|
width: '600px',
|
|
height: '500px',
|
|
height: '500px',
|
|
componentProps: {
|
|
componentProps: {
|
|
- title: '新增维度',
|
|
|
|
|
|
+ title: t('dataReport.addDimension'),
|
|
type: 'add',
|
|
type: 'add',
|
|
dimensionData: {}
|
|
dimensionData: {}
|
|
},
|
|
},
|
|
@@ -228,7 +232,7 @@ const handleAdd = () => {
|
|
const result = await modalRef.handleConfirm()
|
|
const result = await modalRef.handleConfirm()
|
|
if (result) {
|
|
if (result) {
|
|
await api.report.dimensions.add(modalRef.form)
|
|
await api.report.dimensions.add(modalRef.form)
|
|
- ElMessage.success('新增成功')
|
|
|
|
|
|
+ ElMessage.success(t('message.createSuccess'))
|
|
loadData()
|
|
loadData()
|
|
return true
|
|
return true
|
|
}
|
|
}
|
|
@@ -243,7 +247,7 @@ const handleEdit = (row) => {
|
|
width: '600px',
|
|
width: '600px',
|
|
height: '500px',
|
|
height: '500px',
|
|
componentProps: {
|
|
componentProps: {
|
|
- title: '编辑维度',
|
|
|
|
|
|
+ title: t('dataReport.editDimension'),
|
|
type: 'edit',
|
|
type: 'edit',
|
|
dimensionData: row
|
|
dimensionData: row
|
|
},
|
|
},
|
|
@@ -251,7 +255,7 @@ const handleEdit = (row) => {
|
|
const result = await modalRef.handleConfirm()
|
|
const result = await modalRef.handleConfirm()
|
|
if (result) {
|
|
if (result) {
|
|
await api.report.dimensions.update(modalRef.form)
|
|
await api.report.dimensions.update(modalRef.form)
|
|
- ElMessage.success('编辑成功')
|
|
|
|
|
|
+ ElMessage.success(t('message.updateSuccess'))
|
|
loadData()
|
|
loadData()
|
|
return true
|
|
return true
|
|
}
|
|
}
|
|
@@ -265,26 +269,26 @@ const handleEdit = (row) => {
|
|
const handleDelete = async (row) => {
|
|
const handleDelete = async (row) => {
|
|
try {
|
|
try {
|
|
await ElMessageBox.confirm(
|
|
await ElMessageBox.confirm(
|
|
- `确定要删除维度 "${row.name}" 吗?`,
|
|
|
|
- '删除确认',
|
|
|
|
|
|
+ t('dataReport.confirmDeleteDimension', { name: row.name }),
|
|
|
|
+ t('dataReport.deleteConfirmation'),
|
|
{
|
|
{
|
|
- confirmButtonText: '确定',
|
|
|
|
- cancelButtonText: '取消',
|
|
|
|
|
|
+ confirmButtonText: t('common.confirm'),
|
|
|
|
+ cancelButtonText: t('common.cancel'),
|
|
type: 'warning'
|
|
type: 'warning'
|
|
}
|
|
}
|
|
)
|
|
)
|
|
|
|
|
|
const response = await api.report.dimensions.delete(row.id)
|
|
const response = await api.report.dimensions.delete(row.id)
|
|
if (response.code === 200) {
|
|
if (response.code === 200) {
|
|
- ElMessage.success('删除成功')
|
|
|
|
|
|
+ ElMessage.success(t('message.deleteSuccess'))
|
|
loadData()
|
|
loadData()
|
|
} else {
|
|
} else {
|
|
- ElMessage.error(response.message || '删除失败')
|
|
|
|
|
|
+ ElMessage.error(response.message || t('message.deleteFailed'))
|
|
}
|
|
}
|
|
} catch (error) {
|
|
} catch (error) {
|
|
if (error !== 'cancel') {
|
|
if (error !== 'cancel') {
|
|
console.error('删除维度失败:', error)
|
|
console.error('删除维度失败:', error)
|
|
- ElMessage.error('删除失败')
|
|
|
|
|
|
+ ElMessage.error(t('message.deleteFailed'))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -295,15 +299,15 @@ const handleStatusChange = async (row) => {
|
|
status: row.status
|
|
status: row.status
|
|
})
|
|
})
|
|
if (response.code === 200) {
|
|
if (response.code === 200) {
|
|
- ElMessage.success('状态更新成功')
|
|
|
|
|
|
+ ElMessage.success(t('dataReport.statusUpdateSuccess'))
|
|
} else {
|
|
} else {
|
|
- ElMessage.error(response.message || '状态更新失败')
|
|
|
|
|
|
+ ElMessage.error(response.message || t('dataReport.statusUpdateFailed'))
|
|
// 回滚状态
|
|
// 回滚状态
|
|
row.status = row.status === 1 ? 0 : 1
|
|
row.status = row.status === 1 ? 0 : 1
|
|
}
|
|
}
|
|
} catch (error) {
|
|
} catch (error) {
|
|
console.error('更新状态失败:', error)
|
|
console.error('更新状态失败:', error)
|
|
- ElMessage.error('状态更新失败')
|
|
|
|
|
|
+ ElMessage.error(t('dataReport.statusUpdateFailed'))
|
|
// 回滚状态
|
|
// 回滚状态
|
|
row.status = row.status === 1 ? 0 : 1
|
|
row.status = row.status === 1 ? 0 : 1
|
|
}
|
|
}
|
|
@@ -332,64 +336,64 @@ const handleSelectionChange = (selection) => {
|
|
|
|
|
|
const handleBatchDelete = async () => {
|
|
const handleBatchDelete = async () => {
|
|
if (selectedRows.value.length === 0) {
|
|
if (selectedRows.value.length === 0) {
|
|
- ElMessage.warning('请选择要删除的项目')
|
|
|
|
|
|
+ ElMessage.warning($t('dataReport.selectItemsToDelete'))
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
try {
|
|
try {
|
|
await ElMessageBox.confirm(
|
|
await ElMessageBox.confirm(
|
|
- `确定要批量删除 ${selectedRows.value.length} 个项目吗?`,
|
|
|
|
- '批量删除确认',
|
|
|
|
|
|
+ $t('dataReport.confirmBatchDelete', { count: selectedRows.value.length }),
|
|
|
|
+ $t('dataReport.batchDeleteConfirmation'),
|
|
{
|
|
{
|
|
- confirmButtonText: '确定',
|
|
|
|
- cancelButtonText: '取消',
|
|
|
|
|
|
+ confirmButtonText: t('common.confirm'),
|
|
|
|
+ cancelButtonText: t('common.cancel'),
|
|
type: 'warning'
|
|
type: 'warning'
|
|
}
|
|
}
|
|
)
|
|
)
|
|
|
|
|
|
const ids = selectedRows.value.map(row => row.id)
|
|
const ids = selectedRows.value.map(row => row.id)
|
|
// 这里应该调用批量删除API
|
|
// 这里应该调用批量删除API
|
|
- ElMessage.success('批量删除成功')
|
|
|
|
|
|
+ ElMessage.success($t('dataReport.batchDeleteSuccess'))
|
|
loadData()
|
|
loadData()
|
|
} catch (error) {
|
|
} catch (error) {
|
|
if (error !== 'cancel') {
|
|
if (error !== 'cancel') {
|
|
console.error('批量删除失败:', error)
|
|
console.error('批量删除失败:', error)
|
|
- ElMessage.error('批量删除失败')
|
|
|
|
|
|
+ ElMessage.error($t('dataReport.batchDeleteFailed'))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
const handleBatchEnable = async () => {
|
|
const handleBatchEnable = async () => {
|
|
if (selectedRows.value.length === 0) {
|
|
if (selectedRows.value.length === 0) {
|
|
- ElMessage.warning('请选择要启用的项目')
|
|
|
|
|
|
+ ElMessage.warning($t('dataReport.selectItemsToEnable'))
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
try {
|
|
try {
|
|
const ids = selectedRows.value.map(row => row.id)
|
|
const ids = selectedRows.value.map(row => row.id)
|
|
// 这里应该调用批量更新API
|
|
// 这里应该调用批量更新API
|
|
- ElMessage.success('批量启用成功')
|
|
|
|
|
|
+ ElMessage.success($t('dataReport.batchEnableSuccess'))
|
|
loadData()
|
|
loadData()
|
|
} catch (error) {
|
|
} catch (error) {
|
|
console.error('批量启用失败:', error)
|
|
console.error('批量启用失败:', error)
|
|
- ElMessage.error('批量启用失败')
|
|
|
|
|
|
+ ElMessage.error($t('dataReport.batchEnableFailed'))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
const handleBatchDisable = async () => {
|
|
const handleBatchDisable = async () => {
|
|
if (selectedRows.value.length === 0) {
|
|
if (selectedRows.value.length === 0) {
|
|
- ElMessage.warning('请选择要禁用的项目')
|
|
|
|
|
|
+ ElMessage.warning($t('dataReport.selectItemsToDisable'))
|
|
return
|
|
return
|
|
}
|
|
}
|
|
|
|
|
|
try {
|
|
try {
|
|
const ids = selectedRows.value.map(row => row.id)
|
|
const ids = selectedRows.value.map(row => row.id)
|
|
// 这里应该调用批量更新API
|
|
// 这里应该调用批量更新API
|
|
- ElMessage.success('批量禁用成功')
|
|
|
|
|
|
+ ElMessage.success($t('dataReport.batchDisableSuccess'))
|
|
loadData()
|
|
loadData()
|
|
} catch (error) {
|
|
} catch (error) {
|
|
console.error('批量禁用失败:', error)
|
|
console.error('批量禁用失败:', error)
|
|
- ElMessage.error('批量禁用失败')
|
|
|
|
|
|
+ ElMessage.error($t('dataReport.batchDisableFailed'))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|