Files
orion-visor/orion-ops-ui/src/views/asset/host-key/index.vue

65 lines
1.7 KiB
Vue
Raw Normal View History

2023-09-20 12:13:02 +08:00
<template>
2023-12-04 16:08:14 +08:00
<div class="layout-container">
2023-10-07 23:24:12 +08:00
<!-- 列表-表格 -->
<host-key-table v-if="renderTable"
ref="table"
2024-03-20 23:45:31 +08:00
@open-view="(e) => drawer.openView(e)"
@open-add="() => drawer.openAdd()"
@open-update="(e) => drawer.openUpdate(e)" />
2023-10-07 23:24:12 +08:00
<!-- 列表-卡片 -->
<host-key-card-list v-else
ref="card"
2024-03-20 23:45:31 +08:00
@open-view="(e) => drawer.openView(e)"
@open-add="() => drawer.openAdd()"
@open-update="(e) => drawer.openUpdate(e)" />
2023-09-20 12:13:02 +08:00
<!-- 添加修改模态框 -->
2023-09-20 17:13:38 +08:00
<host-key-form-drawer ref="drawer"
2023-10-07 23:24:12 +08:00
@added="modalAddCallback"
@updated="modalUpdateCallback" />
2023-09-20 12:13:02 +08:00
</div>
</template>
<script lang="ts">
export default {
2024-03-07 19:32:04 +08:00
name: 'hostKey'
2023-09-20 12:13:02 +08:00
};
</script>
<script lang="ts" setup>
2023-12-04 16:08:14 +08:00
import { computed, ref } from 'vue';
import { useAppStore } from '@/store';
2023-10-07 23:24:12 +08:00
import HostKeyCardList from './components/host-key-card-list.vue';
2023-09-20 12:13:02 +08:00
import HostKeyTable from './components/host-key-table.vue';
2023-09-20 17:13:38 +08:00
import HostKeyFormDrawer from './components/host-key-form-drawer.vue';
2023-09-20 12:13:02 +08:00
const table = ref();
2023-10-07 23:24:12 +08:00
const card = ref();
2023-09-20 17:13:38 +08:00
const drawer = ref();
2023-10-07 23:24:12 +08:00
const appStore = useAppStore();
const renderTable = computed(() => appStore.hostKeyView === 'table');
// 添加回调
const modalAddCallback = () => {
if (renderTable.value) {
table.value.addedCallback();
} else {
card.value.addedCallback();
}
};
// 修改回调
const modalUpdateCallback = () => {
if (renderTable.value) {
table.value.updatedCallback();
} else {
card.value.updatedCallback();
}
};
2023-09-20 12:13:02 +08:00
</script>
<style lang="less" scoped>
</style>