|
|
|
<template>
|
|
|
|
<div class="h-100" style="overflow: auto">
|
|
|
|
<v-toolbar height="30" class="elevation-0">
|
|
|
|
<v-spacer />
|
|
|
|
<v-btn small outlined @click="loadAudits">
|
|
|
|
<v-icon small class="mr-2">
|
|
|
|
refresh
|
|
|
|
</v-icon>
|
|
|
|
<!-- Reload -->
|
|
|
|
{{ $t('general.reload') }}
|
|
|
|
</v-btn>
|
|
|
|
</v-toolbar>
|
|
|
|
<v-container class="h-100 d-flex flex-column">
|
|
|
|
<v-simple-table
|
|
|
|
v-if="audits"
|
|
|
|
dense
|
|
|
|
style="max-width: 1000px; overflow: auto"
|
|
|
|
class="mx-auto flex-grow-1"
|
|
|
|
>
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th class="caption">
|
|
|
|
<!--Operation Type-->
|
|
|
|
{{ $t('labels.operationType') }}
|
|
|
|
</th>
|
|
|
|
<th class="caption">
|
|
|
|
<!---->
|
|
|
|
{{ $t('labels.operationSubType') }}
|
|
|
|
</th>
|
|
|
|
<th class="caption">
|
|
|
|
<!--Description-->
|
|
|
|
{{ $t('labels.description') }}
|
|
|
|
</th>
|
|
|
|
<th class="caption">
|
|
|
|
<!--User-->
|
|
|
|
{{ $t('objects.user') }}
|
|
|
|
</th>
|
|
|
|
<!-- <th class="caption">Ip</th>-->
|
|
|
|
<th class="caption">
|
|
|
|
<!--Created-->
|
|
|
|
{{ $t('labels.created') }}
|
|
|
|
</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<tr v-for="(audit,i) in audits" :key="i">
|
|
|
|
<td class="caption">
|
|
|
|
{{ audit.op_type }}
|
|
|
|
</td>
|
|
|
|
<td class="caption">
|
|
|
|
{{ audit.op_sub_type }}
|
|
|
|
</td>
|
|
|
|
<td class="caption">
|
|
|
|
{{ audit.description }}
|
|
|
|
</td>
|
|
|
|
<td class="caption">
|
|
|
|
{{ audit.user == null ? 'Shared base' : audit.user }}
|
|
|
|
</td>
|
|
|
|
<!-- <td class="caption">-->
|
|
|
|
<!-- {{ audit.ip }}-->
|
|
|
|
<!-- </td>-->
|
|
|
|
<td class="caption">
|
|
|
|
<v-tooltip bottom>
|
|
|
|
<template #activator="{on}">
|
|
|
|
<span v-on="on">{{ calculateDiff(audit.created_at) }}</span>
|
|
|
|
</template>
|
|
|
|
<span class="caption">{{ audit.created_at }}</span>
|
|
|
|
</v-tooltip>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</tbody>
|
|
|
|
</v-simple-table>
|
|
|
|
<v-pagination
|
|
|
|
v-model="page"
|
|
|
|
:length="Math.ceil(count / limit)"
|
|
|
|
:total-visible="8"
|
|
|
|
@input="loadAudits"
|
|
|
|
/>
|
|
|
|
</v-container>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import { calculateDiff } from '~/helpers'
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'Audit',
|
|
|
|
data: () => ({
|
|
|
|
audits: null,
|
|
|
|
count: 0,
|
|
|
|
limit: 25,
|
|
|
|
page: 1
|
|
|
|
}),
|
|
|
|
created() {
|
|
|
|
this.loadAudits()
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
async loadAudits() {
|
|
|
|
// const { list, count } = await this.$store.dispatch('sqlMgr/ActSqlOp', [null, 'xcAuditList', {
|
|
|
|
// limit: this.limit,
|
|
|
|
// offset: this.limit * (this.page - 1)
|
|
|
|
// }])
|
|
|
|
const {
|
|
|
|
list, pageInfo
|
|
|
|
} = (await this.$api.project.auditList(
|
|
|
|
this.$store.state.project.projectId, {
|
|
|
|
limit: this.limit,
|
|
|
|
offset: this.limit * (this.page - 1)
|
|
|
|
}))
|
|
|
|
|
|
|
|
this.audits = list
|
|
|
|
this.count = pageInfo.totalRows
|
|
|
|
},
|
|
|
|
calculateDiff
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
|
|
</style>
|