mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-04-20 06:20:11 +00:00
## Summary
Fix all i18n `no-restricted-imports` lint warnings and upgrade rules
from `warn` to `error`.
## Changes
- **What**: Migrate Vue components from `import { t/d } from '@/i18n'`
to `const { t } = useI18n()`. Migrate non-component `.ts` files from
`useI18n()` to `import { t/d } from '@/i18n'`. Allow `st` import from
`@/i18n` in Vue components (it wraps `te`/`t` for safe fallback
translation). Remove `@deprecated` tag from `i18n.ts` global exports
(still used by `st` and non-component code). Upgrade both lint rules
from `warn` to `error`.
## Review Focus
- The `st` helper is intentionally excluded from the Vue component
restriction since it provides safe fallback translation needed for
custom node definitions.
Fixes #8701
┆Issue is synchronized with this [Notion
page](https://www.notion.so/PR-8704-fix-resolve-i18n-no-restricted-imports-lint-warnings-2ff6d73d365081ae84d8eb0dfef24323)
by [Unito](https://www.unito.io)
---------
Co-authored-by: Amp <amp@ampcode.com>
194 lines
4.7 KiB
Vue
194 lines
4.7 KiB
Vue
<template>
|
|
<div class="flex flex-col">
|
|
<div class="show-up-direction relative">
|
|
<Button
|
|
v-tooltip.right="{
|
|
value: t('load3d.upDirection'),
|
|
showDelay: 300
|
|
}"
|
|
size="icon"
|
|
variant="textonly"
|
|
class="rounded-full"
|
|
:aria-label="t('load3d.upDirection')"
|
|
@click="toggleUpDirection"
|
|
>
|
|
<i class="pi pi-arrow-up text-lg text-base-foreground" />
|
|
</Button>
|
|
<div
|
|
v-show="showUpDirection"
|
|
class="absolute top-0 left-12 rounded-lg bg-interface-menu-surface shadow-lg"
|
|
>
|
|
<div class="flex flex-col">
|
|
<Button
|
|
v-for="direction in upDirections"
|
|
:key="direction"
|
|
variant="textonly"
|
|
:class="
|
|
cn(
|
|
'text-base-foreground',
|
|
upDirection === direction && 'bg-blue-500'
|
|
)
|
|
"
|
|
@click="selectUpDirection(direction)"
|
|
>
|
|
{{ direction.toUpperCase() }}
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div v-if="!hideMaterialMode" class="show-material-mode relative">
|
|
<Button
|
|
v-tooltip.right="{
|
|
value: t('load3d.materialMode'),
|
|
showDelay: 300
|
|
}"
|
|
size="icon"
|
|
variant="textonly"
|
|
class="rounded-full"
|
|
:aria-label="t('load3d.materialMode')"
|
|
@click="toggleMaterialMode"
|
|
>
|
|
<i class="pi pi-box text-lg text-base-foreground" />
|
|
</Button>
|
|
<div
|
|
v-show="showMaterialMode"
|
|
class="absolute top-0 left-12 rounded-lg bg-interface-menu-surface shadow-lg"
|
|
>
|
|
<div class="flex flex-col">
|
|
<Button
|
|
v-for="mode in materialModes"
|
|
:key="mode"
|
|
variant="textonly"
|
|
:class="
|
|
cn(
|
|
'whitespace-nowrap text-base-foreground',
|
|
materialMode === mode && 'bg-blue-500'
|
|
)
|
|
"
|
|
@click="selectMaterialMode(mode)"
|
|
>
|
|
{{ formatMaterialMode(mode) }}
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div v-if="hasSkeleton">
|
|
<Button
|
|
v-tooltip.right="{
|
|
value: t('load3d.showSkeleton'),
|
|
showDelay: 300
|
|
}"
|
|
size="icon"
|
|
variant="textonly"
|
|
:class="cn('rounded-full', showSkeleton && 'bg-blue-500')"
|
|
:aria-label="t('load3d.showSkeleton')"
|
|
@click="showSkeleton = !showSkeleton"
|
|
>
|
|
<i class="pi pi-sitemap text-lg text-base-foreground" />
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { computed, onMounted, onUnmounted, ref } from 'vue'
|
|
import { useI18n } from 'vue-i18n'
|
|
|
|
import Button from '@/components/ui/button/Button.vue'
|
|
import type {
|
|
MaterialMode,
|
|
UpDirection
|
|
} from '@/extensions/core/load3d/interfaces'
|
|
import { cn } from '@/utils/tailwindUtil'
|
|
|
|
const { t } = useI18n()
|
|
const {
|
|
hideMaterialMode = false,
|
|
isPlyModel = false,
|
|
hasSkeleton = false
|
|
} = defineProps<{
|
|
hideMaterialMode?: boolean
|
|
isPlyModel?: boolean
|
|
hasSkeleton?: boolean
|
|
}>()
|
|
|
|
const materialMode = defineModel<MaterialMode>('materialMode')
|
|
const upDirection = defineModel<UpDirection>('upDirection')
|
|
const showSkeleton = defineModel<boolean>('showSkeleton')
|
|
|
|
const showUpDirection = ref(false)
|
|
const showMaterialMode = ref(false)
|
|
|
|
const upDirections: UpDirection[] = [
|
|
'original',
|
|
'-x',
|
|
'+x',
|
|
'-y',
|
|
'+y',
|
|
'-z',
|
|
'+z'
|
|
]
|
|
|
|
const materialModes = computed(() => {
|
|
const modes: MaterialMode[] = [
|
|
'original',
|
|
'normal',
|
|
'wireframe'
|
|
//'depth' disable for now
|
|
]
|
|
|
|
// Only show pointCloud mode for PLY files (point cloud rendering)
|
|
if (isPlyModel) {
|
|
modes.splice(1, 0, 'pointCloud')
|
|
}
|
|
|
|
return modes
|
|
})
|
|
|
|
function toggleUpDirection() {
|
|
showUpDirection.value = !showUpDirection.value
|
|
showMaterialMode.value = false
|
|
}
|
|
|
|
function selectUpDirection(direction: UpDirection) {
|
|
upDirection.value = direction
|
|
showUpDirection.value = false
|
|
}
|
|
|
|
function toggleMaterialMode() {
|
|
showMaterialMode.value = !showMaterialMode.value
|
|
showUpDirection.value = false
|
|
}
|
|
|
|
function selectMaterialMode(mode: MaterialMode) {
|
|
materialMode.value = mode
|
|
showMaterialMode.value = false
|
|
}
|
|
|
|
function formatMaterialMode(mode: MaterialMode) {
|
|
return t(`load3d.materialModes.${mode}`)
|
|
}
|
|
|
|
function closeSceneSlider(e: MouseEvent) {
|
|
const target = e.target as HTMLElement
|
|
|
|
if (!target.closest('.show-up-direction')) {
|
|
showUpDirection.value = false
|
|
}
|
|
|
|
if (!target.closest('.show-material-mode')) {
|
|
showMaterialMode.value = false
|
|
}
|
|
}
|
|
|
|
onMounted(() => {
|
|
document.addEventListener('click', closeSceneSlider)
|
|
})
|
|
|
|
onUnmounted(() => {
|
|
document.removeEventListener('click', closeSceneSlider)
|
|
})
|
|
</script>
|