mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-03-01 03:04:11 +00:00
## Summary Extracts desktop UI into apps/desktop-ui package with minimal changes. ## Changes - **What**: - Separates desktop-specific code into standalone package with independent Vite config, router, and i18n - Drastically simplifies the main app router by removing all desktop routes - Adds a some code duplication, most due to the existing design - Some duplication can be refactored to be *simpler* on either side - no need to split things by `isElectron()` - Rudimentary storybook support has been added - **Breaking**: Stacked PR for publishing must be merged before this PR makes it to stable core (but publishing _could_ be done manually) - #5915 - **Dependencies**: Takes full advantage of pnpm catalog. No additional dependencies added. ## Review Focus - Should be no changes to normal frontend operation - Scripts added to root package.json are acceptable - The duplication in this PR is copied as is, wherever possible. Any corrections or fix-ups beyond the scope of simply migrating the functionality as-is, can be addressed in later PRs. That said, if any changes are made, it instantly becomes more difficult to separate the duplicated code out into a shared utility. - Tracking issue to address concerns: #5925 ### i18n Fixing i18n is out of scope for this PR. It is a larger task that we should consider carefully and implement properly. Attempting to isolate the desktop i18n and duplicate the _current_ localisation scripts would be wasted energy.
40 lines
1.2 KiB
Vue
40 lines
1.2 KiB
Vue
<template>
|
|
<BaseViewTemplate dark>
|
|
<div class="flex items-center justify-center min-h-screen">
|
|
<div class="grid grid-rows-2 gap-8">
|
|
<!-- Top container: Logo -->
|
|
<div class="flex items-end justify-center">
|
|
<img
|
|
src="/assets/images/comfy-brand-mark.svg"
|
|
:alt="$t('g.logoAlt')"
|
|
class="w-60"
|
|
/>
|
|
</div>
|
|
<!-- Bottom container: Title and button -->
|
|
<div class="flex flex-col items-center justify-center gap-4">
|
|
<Button
|
|
:label="$t('welcome.getStarted')"
|
|
class="px-8 mt-4 bg-brand-yellow hover:bg-brand-yellow/90 border-0 rounded-lg transition-colors"
|
|
:pt="{
|
|
label: { class: 'font-inter text-neutral-900 font-black' }
|
|
}"
|
|
@click="navigateTo('/install')"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</BaseViewTemplate>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import Button from 'primevue/button'
|
|
import { useRouter } from 'vue-router'
|
|
|
|
import BaseViewTemplate from '@/views/templates/BaseViewTemplate.vue'
|
|
|
|
const router = useRouter()
|
|
const navigateTo = async (path: string) => {
|
|
await router.push(path)
|
|
}
|
|
</script>
|