summaryrefslogtreecommitdiff
path: root/src/client/pages/instance/queue.vue
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2020-01-30 04:37:25 +0900
committerGitHub <noreply@github.com>2020-01-30 04:37:25 +0900
commitf6154dc0af1a0d65819e87240f4385f9573095cb (patch)
tree699a5ca07d6727b7f8497d4769f25d6d62f94b5a /src/client/pages/instance/queue.vue
parentAdd Event activity-type support (#5785) (diff)
downloadsharkey-f6154dc0af1a0d65819e87240f4385f9573095cb.tar.gz
sharkey-f6154dc0af1a0d65819e87240f4385f9573095cb.tar.bz2
sharkey-f6154dc0af1a0d65819e87240f4385f9573095cb.zip
v12 (#5712)
Co-authored-by: MeiMei <30769358+mei23@users.noreply.github.com> Co-authored-by: Satsuki Yanagi <17376330+u1-liquid@users.noreply.github.com>
Diffstat (limited to 'src/client/pages/instance/queue.vue')
-rw-r--r--src/client/pages/instance/queue.vue79
1 files changed, 79 insertions, 0 deletions
diff --git a/src/client/pages/instance/queue.vue b/src/client/pages/instance/queue.vue
new file mode 100644
index 0000000000..b7e633081f
--- /dev/null
+++ b/src/client/pages/instance/queue.vue
@@ -0,0 +1,79 @@
+<template>
+<div>
+ <x-queue :connection="connection" domain="inbox">
+ <template #title><fa :icon="faExchangeAlt"/> In</template>
+ </x-queue>
+ <x-queue :connection="connection" domain="deliver">
+ <template #title><fa :icon="faExchangeAlt"/> Out</template>
+ </x-queue>
+ <section class="_section">
+ <div class="_content">
+ <mk-button @click="clear()"><fa :icon="faTrashAlt"/> {{ $t('clearQueue') }}</mk-button>
+ </div>
+ </section>
+</div>
+</template>
+
+<script lang="ts">
+import Vue from 'vue';
+import { faExchangeAlt } from '@fortawesome/free-solid-svg-icons';
+import { faTrashAlt } from '@fortawesome/free-regular-svg-icons';
+import i18n from '../../i18n';
+import MkButton from '../../components/ui/button.vue';
+import XQueue from './queue.queue.vue';
+
+export default Vue.extend({
+ i18n,
+
+ metaInfo() {
+ return {
+ title: `${this.$t('jobQueue')} | ${this.$t('instance')}`
+ };
+ },
+
+ components: {
+ MkButton,
+ XQueue,
+ },
+
+ data() {
+ return {
+ connection: this.$root.stream.useSharedConnection('queueStats'),
+ faExchangeAlt, faTrashAlt
+ }
+ },
+
+ mounted() {
+ this.$nextTick(() => {
+ this.connection.send('requestLog', {
+ id: Math.random().toString().substr(2, 8),
+ length: 200
+ });
+ });
+ },
+
+ beforeDestroy() {
+ this.connection.dispose();
+ },
+
+ methods: {
+ clear() {
+ this.$root.dialog({
+ type: 'warning',
+ title: this.$t('clearQueueConfirmTitle'),
+ text: this.$t('clearQueueConfirmText'),
+ showCancelButton: true
+ }).then(({ canceled }) => {
+ if (canceled) return;
+
+ this.$root.api('admin/queue/clear', {}).then(() => {
+ this.$root.dialog({
+ type: 'success',
+ iconOnly: true, autoClose: true
+ });
+ });
+ });
+ }
+ }
+});
+</script>