Files
orion-visor/orion-ops-ui/src/views/system/dict-value/index.vue

64 lines
1.8 KiB
Vue
Raw Normal View History

2023-10-20 17:07:53 +08:00
<template>
2023-12-04 14:35:18 +08:00
<div class="layout-container">
2023-10-20 17:07:53 +08:00
<!-- 列表-表格 -->
<dict-value-table ref="table"
2023-10-20 18:45:21 +08:00
@openAdd="() => modal.openAdd()"
2023-10-31 01:32:13 +08:00
@openUpdate="(e) => modal.openUpdate(e)"
@openHistory="(e) => history.open(e.id, e.label)" />
2023-10-20 17:07:53 +08:00
<!-- 添加修改模态框 -->
<dict-value-form-modal ref="modal"
2023-10-20 18:45:21 +08:00
@added="modalAddCallback"
@updated="modalUpdateCallback" />
2023-10-31 01:32:13 +08:00
<!-- 历史值模态框 -->
<history-value-modal ref="history"
:type="historyType"
:rollback="rollback"
@updated="modalUpdateCallback" />
2023-10-20 17:07:53 +08:00
</div>
</template>
<script lang="ts">
export default {
2024-03-07 19:32:04 +08:00
name: 'dictValue'
2023-10-20 17:07:53 +08:00
};
</script>
<script lang="ts" setup>
2023-12-04 14:35:18 +08:00
import { ref, onUnmounted } from 'vue';
2023-10-31 01:32:13 +08:00
import { historyType } from './types/const';
2023-10-20 18:45:21 +08:00
import { useCacheStore } from '@/store';
2023-10-31 01:32:13 +08:00
import { rollbackDictValue } from '@/api/system/dict-value';
2024-03-07 23:00:34 +08:00
import DictValueTable from './components/dict-value-table.vue';
import DictValueFormModal from './components/dict-value-form-modal.vue';
import HistoryValueModal from '@/components/meta/history/modal/index.vue';
2023-10-20 17:07:53 +08:00
const table = ref();
const modal = ref();
2023-10-31 01:32:13 +08:00
const history = ref();
2023-10-20 18:45:21 +08:00
const cacheStore = useCacheStore();
2023-10-20 17:07:53 +08:00
// 添加回调
const modalAddCallback = () => {
table.value.addedCallback();
};
// 修改回调
const modalUpdateCallback = () => {
table.value.updatedCallback();
};
2023-10-31 01:32:13 +08:00
// 回滚
const rollback = async (id: number, valueId: number) => {
await rollbackDictValue({ id, valueId });
};
2023-10-20 18:45:21 +08:00
// 卸载时清除 cache
onUnmounted(() => {
cacheStore.reset('dictKeys');
2023-10-20 18:45:21 +08:00
});
2023-10-20 17:07:53 +08:00
</script>
<style lang="less" scoped>
</style>