mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-01-27 03:19:56 +00:00
* Batch move global scope i18n to g. namespace * Minor fix * Update locale * Update locales [skip ci] * More moves * Regroup icon/color * nit * Fix component test --------- Co-authored-by: github-actions <github-actions@github.com>
129 lines
3.7 KiB
Vue
129 lines
3.7 KiB
Vue
<template>
|
|
<div ref="container" class="node-lib-node-container">
|
|
<TreeExplorerTreeNode :node="node">
|
|
<template #before-label>
|
|
<Tag
|
|
v-if="nodeDef.experimental"
|
|
:value="$t('g.experimental')"
|
|
severity="primary"
|
|
/>
|
|
<Tag
|
|
v-if="nodeDef.deprecated"
|
|
:value="$t('g.deprecated')"
|
|
severity="danger"
|
|
/>
|
|
</template>
|
|
<template #actions>
|
|
<Button
|
|
class="bookmark-button"
|
|
size="small"
|
|
:icon="isBookmarked ? 'pi pi-bookmark-fill' : 'pi pi-bookmark'"
|
|
text
|
|
severity="secondary"
|
|
@click.stop="toggleBookmark"
|
|
/>
|
|
</template>
|
|
</TreeExplorerTreeNode>
|
|
|
|
<teleport v-if="isHovered" to="#node-library-node-preview-container">
|
|
<div class="node-lib-node-preview" :style="nodePreviewStyle">
|
|
<NodePreview ref="previewRef" :nodeDef="nodeDef"></NodePreview>
|
|
</div>
|
|
</teleport>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import Button from 'primevue/button'
|
|
import Tag from 'primevue/tag'
|
|
import TreeExplorerTreeNode from '@/components/common/TreeExplorerTreeNode.vue'
|
|
import NodePreview from '@/components/node/NodePreview.vue'
|
|
import { ComfyNodeDefImpl } from '@/stores/nodeDefStore'
|
|
import {
|
|
computed,
|
|
CSSProperties,
|
|
nextTick,
|
|
onMounted,
|
|
onUnmounted,
|
|
ref
|
|
} from 'vue'
|
|
import { RenderedTreeExplorerNode } from '@/types/treeExplorerTypes'
|
|
import { useNodeBookmarkStore } from '@/stores/nodeBookmarkStore'
|
|
import { useSettingStore } from '@/stores/settingStore'
|
|
|
|
const props = defineProps<{
|
|
node: RenderedTreeExplorerNode<ComfyNodeDefImpl>
|
|
}>()
|
|
|
|
const nodeDef = computed(() => props.node.data)
|
|
const nodeBookmarkStore = useNodeBookmarkStore()
|
|
const isBookmarked = computed(() =>
|
|
nodeBookmarkStore.isBookmarked(nodeDef.value)
|
|
)
|
|
const settingStore = useSettingStore()
|
|
const sidebarLocation = computed<'left' | 'right'>(() =>
|
|
settingStore.get('Comfy.Sidebar.Location')
|
|
)
|
|
|
|
const emit = defineEmits<{
|
|
(e: 'toggle-bookmark', value: ComfyNodeDefImpl): void
|
|
}>()
|
|
|
|
const toggleBookmark = () => {
|
|
nodeBookmarkStore.toggleBookmark(nodeDef.value)
|
|
}
|
|
|
|
const previewRef = ref<InstanceType<typeof NodePreview> | null>(null)
|
|
const nodePreviewStyle = ref<CSSProperties>({
|
|
position: 'absolute',
|
|
top: '0px',
|
|
left: '0px'
|
|
})
|
|
|
|
const handleNodeHover = async () => {
|
|
const hoverTarget = nodeContentElement.value
|
|
const targetRect = hoverTarget.getBoundingClientRect()
|
|
|
|
const previewHeight = previewRef.value?.$el.offsetHeight || 0
|
|
const availableSpaceBelow = window.innerHeight - targetRect.bottom
|
|
|
|
nodePreviewStyle.value.top =
|
|
previewHeight > availableSpaceBelow
|
|
? `${Math.max(0, targetRect.top - (previewHeight - availableSpaceBelow) - 20)}px`
|
|
: `${targetRect.top - 40}px`
|
|
if (sidebarLocation.value === 'left') {
|
|
nodePreviewStyle.value.left = `${targetRect.right}px`
|
|
} else {
|
|
nodePreviewStyle.value.left = `${targetRect.left - 400}px`
|
|
}
|
|
}
|
|
|
|
const container = ref<HTMLElement | null>(null)
|
|
const nodeContentElement = ref<HTMLElement | null>(null)
|
|
const isHovered = ref(false)
|
|
const handleMouseEnter = async () => {
|
|
isHovered.value = true
|
|
await nextTick()
|
|
handleNodeHover()
|
|
}
|
|
const handleMouseLeave = () => {
|
|
isHovered.value = false
|
|
}
|
|
onMounted(() => {
|
|
nodeContentElement.value = container.value?.closest('.p-tree-node-content')
|
|
nodeContentElement.value?.addEventListener('mouseenter', handleMouseEnter)
|
|
nodeContentElement.value?.addEventListener('mouseleave', handleMouseLeave)
|
|
})
|
|
|
|
onUnmounted(() => {
|
|
nodeContentElement.value?.removeEventListener('mouseenter', handleMouseEnter)
|
|
nodeContentElement.value?.removeEventListener('mouseleave', handleMouseLeave)
|
|
})
|
|
</script>
|
|
|
|
<style scoped>
|
|
.node-lib-node-container {
|
|
@apply h-full w-full;
|
|
}
|
|
</style>
|