mirror of https://github.com/requarks/wiki
199 lines
4.9 KiB
199 lines
4.9 KiB
<template lang='pug'>
|
|
q-page.admin-webhooks
|
|
.row.q-pa-md.items-center
|
|
.col-auto
|
|
img.admin-icon.animated.fadeInLeft(src='/_assets/icons/fluent-lightning-bolt.svg')
|
|
.col.q-pl-md
|
|
.text-h5.text-primary.animated.fadeInLeft {{ t('admin.webhooks.title') }}
|
|
.text-subtitle1.text-grey.animated.fadeInLeft.wait-p2s {{ t('admin.webhooks.subtitle') }}
|
|
.col-auto
|
|
q-btn.q-mr-sm.acrylic-btn(
|
|
icon='las la-question-circle'
|
|
flat
|
|
color='grey'
|
|
:href='siteStore.docsBase + `/system/webhooks`'
|
|
target='_blank'
|
|
type='a'
|
|
)
|
|
q-btn.acrylic-btn.q-mr-sm(
|
|
icon='las la-redo-alt'
|
|
flat
|
|
color='secondary'
|
|
:loading='state.loading > 0'
|
|
@click='load'
|
|
)
|
|
q-btn(
|
|
unelevated
|
|
icon='las la-plus'
|
|
:label='t(`admin.webhooks.new`)'
|
|
color='primary'
|
|
@click='createHook'
|
|
)
|
|
q-separator(inset)
|
|
.row.q-pa-md.q-col-gutter-md
|
|
.col-12(v-if='state.hooks.length < 1')
|
|
q-card.rounded-borders(
|
|
flat
|
|
:class='$q.dark.isActive ? `bg-dark-5 text-white` : `bg-grey-3 text-dark`'
|
|
)
|
|
q-card-section.items-center(horizontal)
|
|
q-card-section.col-auto.q-pr-none
|
|
q-icon(name='las la-info-circle', size='sm')
|
|
q-card-section.text-caption {{ t('admin.webhooks.none') }}
|
|
.col-12(v-else)
|
|
q-card
|
|
q-list(separator)
|
|
q-item(v-for='hook of state.hooks', :key='hook.id')
|
|
q-item-section(side)
|
|
q-icon(name='las la-bolt', color='primary')
|
|
q-item-section
|
|
q-item-label {{hook.name}}
|
|
q-item-label(caption) {{hook.url}}
|
|
q-item-section(side, style='flex-direction: row; align-items: center;')
|
|
template(v-if='hook.state === `pending`')
|
|
q-spinner-clock.q-mr-sm(
|
|
color='indigo'
|
|
size='xs'
|
|
)
|
|
.text-caption.text-indigo {{t('admin.webhooks.statePending')}}
|
|
q-tooltip(anchor='center left', self='center right') {{t('admin.webhooks.statePendingHint')}}
|
|
template(v-else-if='hook.state === `success`')
|
|
q-spinner-infinity.q-mr-sm(
|
|
color='positive'
|
|
size='xs'
|
|
)
|
|
.text-caption.text-positive {{t('admin.webhooks.stateSuccess')}}
|
|
q-tooltip(anchor='center left', self='center right') {{t('admin.webhooks.stateSuccessHint')}}
|
|
template(v-else-if='hook.state === `error`')
|
|
q-icon.q-mr-sm(
|
|
color='negative'
|
|
size='xs'
|
|
name='las la-exclamation-triangle'
|
|
)
|
|
.text-caption.text-negative {{t('admin.webhooks.stateError')}}
|
|
q-tooltip(anchor='center left', self='center right') {{t('admin.webhooks.stateErrorHint')}}
|
|
q-separator.q-ml-md(vertical)
|
|
q-item-section(side, style='flex-direction: row; align-items: center;')
|
|
q-btn.acrylic-btn.q-mr-sm(
|
|
color='indigo'
|
|
icon='las la-pen'
|
|
label='Edit'
|
|
flat
|
|
no-caps
|
|
@click='editHook(hook.id)'
|
|
)
|
|
q-btn.acrylic-btn(
|
|
color='red'
|
|
icon='las la-trash'
|
|
flat
|
|
@click='deleteHook(hook)'
|
|
)
|
|
|
|
</template>
|
|
|
|
<script setup>
|
|
import { cloneDeep } from 'lodash-es'
|
|
import gql from 'graphql-tag'
|
|
|
|
import { useI18n } from 'vue-i18n'
|
|
import { useMeta, useQuasar } from 'quasar'
|
|
import { onMounted, reactive } from 'vue'
|
|
|
|
import { useSiteStore } from 'src/stores/site'
|
|
|
|
import WebhookEditDialog from 'src/components/WebhookEditDialog.vue'
|
|
import WebhookDeleteDialog from 'src/components/WebhookDeleteDialog.vue'
|
|
|
|
// QUASAR
|
|
|
|
const $q = useQuasar()
|
|
|
|
// STORES
|
|
|
|
const siteStore = useSiteStore()
|
|
|
|
// I18N
|
|
|
|
const { t } = useI18n()
|
|
|
|
// META
|
|
|
|
useMeta({
|
|
title: t('admin.webhooks.title')
|
|
})
|
|
|
|
// DATA
|
|
|
|
const state = reactive({
|
|
hooks: [],
|
|
loading: 0
|
|
})
|
|
|
|
// METHODS
|
|
|
|
async function load () {
|
|
state.loading++
|
|
$q.loading.show()
|
|
const resp = await APOLLO_CLIENT.query({
|
|
query: gql`
|
|
query getHooks {
|
|
hooks {
|
|
id
|
|
name
|
|
url
|
|
state
|
|
}
|
|
}
|
|
`,
|
|
fetchPolicy: 'network-only'
|
|
})
|
|
state.hooks = cloneDeep(resp?.data?.hooks) ?? []
|
|
$q.loading.hide()
|
|
state.loading--
|
|
}
|
|
|
|
function createHook () {
|
|
$q.dialog({
|
|
component: WebhookEditDialog,
|
|
componentProps: {
|
|
hookId: null
|
|
}
|
|
}).onOk(() => {
|
|
load()
|
|
})
|
|
}
|
|
|
|
function editHook (id) {
|
|
$q.dialog({
|
|
component: WebhookEditDialog,
|
|
componentProps: {
|
|
hookId: id
|
|
}
|
|
}).onOk(() => {
|
|
load()
|
|
})
|
|
}
|
|
|
|
function deleteHook (hook) {
|
|
$q.dialog({
|
|
component: WebhookDeleteDialog,
|
|
componentProps: {
|
|
hook
|
|
}
|
|
}).onOk(() => {
|
|
load()
|
|
})
|
|
}
|
|
|
|
// MOUNTED
|
|
|
|
onMounted(() => {
|
|
load()
|
|
})
|
|
|
|
</script>
|
|
|
|
<style lang='scss'>
|
|
|
|
</style>
|