12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- <template>
- <div class="flex flex-col">
- <div
- class="bg-primary border-dividerLight sticky top-0 z-10 flex items-center justify-between flex-1 pl-4 border-b"
- >
- <label for="log" class="text-secondaryLight py-2 font-semibold">
- {{ title }}
- </label>
- </div>
- <div ref="logsRef" name="log" class="realtime-log">
- <span v-if="log" class="space-y-2">
- <span
- v-for="(entry, index) in log"
- :key="`entry-${index}`"
- :style="{ color: entry.color }"
- >{{ entry.ts }}{{ source(entry.source) }}{{ entry.payload }}</span
- >
- </span>
- <span v-else>{{ t("response.waiting_for_connection") }}</span>
- </div>
- </div>
- </template>
- <script setup lang="ts">
- import { nextTick, ref, watch } from "@nuxtjs/composition-api"
- import { getSourcePrefix as source } from "~/helpers/utils/string"
- import { useI18n } from "~/helpers/utils/composables"
- const t = useI18n()
- const props = defineProps({
- log: { type: Array, default: () => [] },
- title: {
- type: String,
- default: "",
- },
- })
- const logsRef = ref<any | null>(null)
- const BOTTOM_SCROLL_DIST_INNACURACY = 5
- watch(
- () => props.log,
- () => {
- if (!logsRef.value) return
- const distToBottom =
- logsRef.value.scrollHeight -
- logsRef.value.scrollTop -
- logsRef.value.clientHeight
- if (distToBottom < BOTTOM_SCROLL_DIST_INNACURACY) {
- nextTick(() => (logsRef.value.scrollTop = logsRef.value.scrollHeight))
- }
- }
- )
- </script>
- <style scoped lang="scss">
- .realtime-log {
- @apply p-4;
- @apply bg-transparent;
- @apply text-secondary;
- @apply overflow-auto;
- height: 256px;
- &,
- span {
- @apply select-text;
- }
- span {
- @apply block;
- @apply break-words break-all;
- }
- }
- </style>
|