summaryrefslogtreecommitdiff
path: root/src/client/app/admin/views/db.vue
blob: 9f87a749b6d22811619dbc01aea5caef430254ed (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<template>
<div>
	<ui-card>
		<template #title><fa :icon="faDatabase"/> {{ $t('tables') }}</template>
		<section v-if="tables">
			<div v-for="table in Object.keys(tables)"><b>{{ table }}</b> {{ tables[table].count | number }} {{ tables[table].size | bytes }}</div>
		</section>
		<section>
			<header><fa :icon="faBroom"/> {{ $t('vacuum') }}</header>
			<ui-info>{{ $t('vacuum-info') }}</ui-info>
			<ui-switch v-model="fullVacuum">FULL</ui-switch>
			<ui-switch v-model="analyzeVacuum">ANALYZE</ui-switch>
			<ui-button @click="vacuum()"><fa :icon="faBroom"/> {{ $t('vacuum') }}</ui-button>
			<ui-info warn>{{ $t('vacuum-exclamation') }}</ui-info>
		</section>
	</ui-card>
</div>
</template>

<script lang="ts">
import Vue from 'vue';
import i18n from '../../i18n';
import { faDatabase, faBroom } from '@fortawesome/free-solid-svg-icons';

export default Vue.extend({
	i18n: i18n('admin/views/db.vue'),

	data() {
		return {
			tables: null,
			fullVacuum: true,
			analyzeVacuum: true,
			faDatabase, faBroom
		};
	},

	mounted() {
		this.fetch();
	},

	methods: {
		fetch() {
			this.$root.api('admin/get-table-stats').then(tables => {
				this.tables = tables;
			});
		},

		vacuum() {
			this.$root.api('admin/vacuum', {
				full: this.fullVacuum,
				analyze: this.analyzeVacuum,
			}).then(() => {
				this.$root.dialog({
					type: 'success',
					splash: true
				});
			});
		},
	}
});
</script>