You've already forked AstralRinth
bd97ace974
* feat: implement access tab with dummy data * fix: spacing * feat: qa * feat: implement backend * qa: qa pass * feat: fix user "search" * fix: lint * feat: change to bitfield * feat: fix fields * fix: lint * fix: lint * feat: hook up api * feat: fix permissions * feat: audit log table event start * feat: better mobile mode for audit log table * feat: i18n * feat: qa * feat: enforce permissions * feat: email template start * feat: qa * fix: tooltip bug * feat: qa * impl: sse support in api-client * feat: sse impl * fix: desync path * feat: time frame picker from analytics * feat: QA * fix: spacing * fix: permisison audit log entries * fix: hosting manage page shared server detection * fix: lint * feat: qa + lint * feat: audit log table sort by time * feat: finish frontend panel stuff * fix: lint * fix: backend alignment * fix: lint * fix: supress friend errors * feat: qa * fix: qa * fix: lint * fix: utils barrel * fix: safari cookies in dev * fix: pin nuxt * feat: fixes + notif fix * fix: notifications * feat: qa * fix: notification sync not happening immediately * fix: qa * fix: qa * feat: qa * blog + prepr * feat: toast shit * blog images * thumbnail update one last time * prepr * feat: use reinvite route * update images * fix: reinvite stuff * fix: lint * fix: alignment of save bar * fix: notif sizing * fix: split up access * fix: lint * fix: lint * fix: link --------- Co-authored-by: Prospector <6166773+Prospector@users.noreply.github.com>
101 lines
2.9 KiB
Vue
101 lines
2.9 KiB
Vue
<template>
|
|
<BaseEvent>
|
|
<span
|
|
v-if="isDeleted"
|
|
class="inline-flex min-w-0 max-w-full flex-wrap items-center gap-1 whitespace-normal align-middle @[800px]:flex-nowrap @[800px]:whitespace-nowrap"
|
|
>
|
|
<span class="shrink-0">{{ formatMessage(messages.deletedLabel) }}</span>
|
|
<EventEntityList
|
|
class="min-w-0"
|
|
:entities="addonEntities"
|
|
:limit="1"
|
|
single-line
|
|
entity-text-weight="semibold"
|
|
/>
|
|
</span>
|
|
<IntlFormatted v-else :message-id="message">
|
|
<template #content>
|
|
<EventEntityList
|
|
:entities="addonEntities"
|
|
:single-line="true"
|
|
:limit="contentLimit"
|
|
entity-text-weight="semibold"
|
|
/>
|
|
</template>
|
|
<template #files>
|
|
<EventEntityList :entities="fileNames ?? []" :single-line="true" :limit="1" />
|
|
</template>
|
|
</IntlFormatted>
|
|
</BaseEvent>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { computed } from 'vue'
|
|
|
|
import { defineMessages, type MessageDescriptor, useVIntl } from '../../../../composables/i18n'
|
|
import IntlFormatted from '../../../base/IntlFormatted.vue'
|
|
import BaseEvent from './BaseEvent.vue'
|
|
import EventEntityList from './EventEntityList.vue'
|
|
import type { AuditAddonEventItem, EventEntity } from './types'
|
|
|
|
const props = defineProps<{
|
|
kind: string
|
|
addons?: AuditAddonEventItem[]
|
|
fileNames?: EventEntity[]
|
|
}>()
|
|
|
|
const { formatMessage } = useVIntl()
|
|
|
|
const messages = defineMessages({
|
|
added: {
|
|
id: 'servers.audit-log.event.addon-added',
|
|
defaultMessage: 'Added content <content></content>',
|
|
},
|
|
uploaded: {
|
|
id: 'servers.audit-log.event.addon-uploaded',
|
|
defaultMessage: 'Uploaded <files></files>',
|
|
},
|
|
disabled: {
|
|
id: 'servers.audit-log.event.addon-disabled',
|
|
defaultMessage: 'Disabled content <content></content>',
|
|
},
|
|
enabled: {
|
|
id: 'servers.audit-log.event.addon-enabled',
|
|
defaultMessage: 'Enabled content <content></content>',
|
|
},
|
|
deleted: {
|
|
id: 'servers.audit-log.event.addon-deleted',
|
|
defaultMessage: 'Deleted content <content></content>',
|
|
},
|
|
deletedLabel: {
|
|
id: 'servers.audit-log.event.addon-deleted-label',
|
|
defaultMessage: 'Deleted content',
|
|
},
|
|
updated: {
|
|
id: 'servers.audit-log.event.addon-updated',
|
|
defaultMessage: 'Updated content <content></content>',
|
|
},
|
|
changed: {
|
|
id: 'servers.audit-log.event.addon-changed',
|
|
defaultMessage: 'Changed content <content></content>',
|
|
},
|
|
})
|
|
|
|
const kindMessages: Record<string, MessageDescriptor> = {
|
|
added: messages.added,
|
|
uploaded: messages.uploaded,
|
|
disabled: messages.disabled,
|
|
enabled: messages.enabled,
|
|
deleted: messages.deleted,
|
|
updated: messages.updated,
|
|
}
|
|
|
|
const message = computed(() => kindMessages[props.kind] ?? messages.changed)
|
|
const addonEntities = computed(() => props.addons?.map((addon) => addon.project) ?? [])
|
|
const isDeleted = computed(() => props.kind === 'deleted')
|
|
const shouldShowSingleItem = computed(() =>
|
|
['added', 'disabled', 'enabled', 'updated'].includes(props.kind),
|
|
)
|
|
const contentLimit = computed(() => (shouldShowSingleItem.value ? 1 : undefined))
|
|
</script>
|