mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-03-10 15:40:24 +00:00
* refactor: move settingStore to platform/settings Move src/stores/settingStore.ts to src/platform/settings/settingStore.ts to separate platform infrastructure from domain logic following DDD principles. Updates all import references across ~70 files to maintain compatibility. * fix: update remaining settingStore imports after rebase * fix: complete remaining settingStore import updates * fix: update vi.mock paths for settingStore in tests Update all test files to mock the new settingStore location at @/platform/settings/settingStore instead of @/stores/settingStore * fix: resolve remaining settingStore imports and unused imports after rebase * fix: update settingStore mock path in SelectionToolbox test Fix vi.mock path from @/stores/settingStore to @/platform/settings/settingStore to resolve failing Load3D viewer button test. * refactor: complete comprehensive settings migration to platform layer This commit completes the migration of all settings-related code to the platform layer as part of the Domain-Driven Design (DDD) architecture refactoring. - constants/coreSettings.ts → platform/settings/constants/coreSettings.ts - types/settingTypes.ts → platform/settings/types.ts - stores/settingStore.ts → platform/settings/settingStore.ts (already moved) - composables/setting/useSettingUI.ts → platform/settings/composables/useSettingUI.ts - composables/setting/useSettingSearch.ts → platform/settings/composables/useSettingSearch.ts - composables/useLitegraphSettings.ts → platform/settings/composables/useLitegraphSettings.ts - components/dialog/content/SettingDialogContent.vue → platform/settings/components/SettingDialogContent.vue - components/dialog/content/setting/SettingItem.vue → platform/settings/components/SettingItem.vue - components/dialog/content/setting/SettingGroup.vue → platform/settings/components/SettingGroup.vue - components/dialog/content/setting/SettingsPanel.vue → platform/settings/components/SettingsPanel.vue - components/dialog/content/setting/ColorPaletteMessage.vue → platform/settings/components/ColorPaletteMessage.vue - components/dialog/content/setting/ExtensionPanel.vue → platform/settings/components/ExtensionPanel.vue - components/dialog/content/setting/ServerConfigPanel.vue → platform/settings/components/ServerConfigPanel.vue - ~100+ import statements updated across the codebase - Test file imports corrected - Component imports fixed in dialog service and command menubar - Composable imports updated in GraphCanvas.vue ``` src/platform/settings/ ├── components/ # All settings UI components ├── composables/ # Settings-related composables ├── constants/ # Core settings definitions ├── types.ts # Settings type definitions └── settingStore.ts # Central settings state management ``` ✅ TypeScript compilation successful ✅ All tests passing (settings store, search functionality, UI components) ✅ Production build successful ✅ Domain boundaries properly established This migration consolidates all settings functionality into a cohesive platform domain, improving maintainability and following DDD principles for better code organization. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> * fix: format and lint after rebase conflict resolution * fix: update remaining import paths to platform settings - Fix browser test import: extensionAPI.spec.ts - Fix script import: collect-i18n-general.ts - Complete settings migration import path updates 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> --------- Co-authored-by: Claude <noreply@anthropic.com>
119 lines
3.5 KiB
Vue
119 lines
3.5 KiB
Vue
<template>
|
|
<teleport :to="teleportTarget">
|
|
<nav class="side-tool-bar-container" :class="{ 'small-sidebar': isSmall }">
|
|
<SidebarIcon
|
|
v-for="tab in tabs"
|
|
:key="tab.id"
|
|
:icon="tab.icon"
|
|
:icon-badge="tab.iconBadge"
|
|
:tooltip="tab.tooltip"
|
|
:tooltip-suffix="getTabTooltipSuffix(tab)"
|
|
:label="tab.label || tab.title"
|
|
:is-small="isSmall"
|
|
:selected="tab.id === selectedTab?.id"
|
|
:class="tab.id + '-tab-button'"
|
|
@click="onTabClick(tab)"
|
|
/>
|
|
<SidebarTemplatesButton />
|
|
<div class="side-tool-bar-end">
|
|
<SidebarLogoutIcon v-if="userStore.isMultiUserServer" />
|
|
<SidebarHelpCenterIcon />
|
|
<SidebarBottomPanelToggleButton />
|
|
<SidebarShortcutsToggleButton />
|
|
</div>
|
|
</nav>
|
|
</teleport>
|
|
<div
|
|
v-if="selectedTab"
|
|
class="sidebar-content-container h-full overflow-y-auto overflow-x-hidden"
|
|
>
|
|
<ExtensionSlot :extension="selectedTab" />
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { computed } from 'vue'
|
|
|
|
import ExtensionSlot from '@/components/common/ExtensionSlot.vue'
|
|
import SidebarBottomPanelToggleButton from '@/components/sidebar/SidebarBottomPanelToggleButton.vue'
|
|
import SidebarShortcutsToggleButton from '@/components/sidebar/SidebarShortcutsToggleButton.vue'
|
|
import { useSettingStore } from '@/platform/settings/settingStore'
|
|
import { useKeybindingStore } from '@/stores/keybindingStore'
|
|
import { useUserStore } from '@/stores/userStore'
|
|
import { useWorkspaceStore } from '@/stores/workspaceStore'
|
|
import type { SidebarTabExtension } from '@/types/extensionTypes'
|
|
|
|
import SidebarHelpCenterIcon from './SidebarHelpCenterIcon.vue'
|
|
import SidebarIcon from './SidebarIcon.vue'
|
|
import SidebarLogoutIcon from './SidebarLogoutIcon.vue'
|
|
import SidebarTemplatesButton from './SidebarTemplatesButton.vue'
|
|
|
|
const workspaceStore = useWorkspaceStore()
|
|
const settingStore = useSettingStore()
|
|
const userStore = useUserStore()
|
|
|
|
const teleportTarget = computed(() =>
|
|
settingStore.get('Comfy.Sidebar.Location') === 'left'
|
|
? '.comfyui-body-left'
|
|
: '.comfyui-body-right'
|
|
)
|
|
|
|
const isSmall = computed(
|
|
() => settingStore.get('Comfy.Sidebar.Size') === 'small'
|
|
)
|
|
|
|
const tabs = computed(() => workspaceStore.getSidebarTabs())
|
|
const selectedTab = computed(() => workspaceStore.sidebarTab.activeSidebarTab)
|
|
const onTabClick = (item: SidebarTabExtension) => {
|
|
workspaceStore.sidebarTab.toggleSidebarTab(item.id)
|
|
}
|
|
const keybindingStore = useKeybindingStore()
|
|
const getTabTooltipSuffix = (tab: SidebarTabExtension) => {
|
|
const keybinding = keybindingStore.getKeybindingByCommandId(
|
|
`Workspace.ToggleSidebarTab.${tab.id}`
|
|
)
|
|
return keybinding ? ` (${keybinding.combo.toString()})` : ''
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
/* Global CSS variables for sidebar
|
|
* These variables need to be global (not scoped) because they are used by
|
|
* teleported components like WhatsNewPopup that render outside the sidebar
|
|
* but need to reference sidebar dimensions for proper positioning.
|
|
*/
|
|
:root {
|
|
--sidebar-width: 4rem;
|
|
--sidebar-icon-size: 1rem;
|
|
}
|
|
|
|
:root:has(.side-tool-bar-container.small-sidebar) {
|
|
--sidebar-width: 2.5rem;
|
|
}
|
|
</style>
|
|
|
|
<style scoped>
|
|
.side-tool-bar-container {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
|
|
width: var(--sidebar-width);
|
|
height: 100%;
|
|
|
|
background-color: var(--comfy-menu-secondary-bg);
|
|
color: var(--fg-color);
|
|
box-shadow: var(--bar-shadow);
|
|
}
|
|
|
|
.side-tool-bar-container.small-sidebar {
|
|
--sidebar-width: 2.5rem;
|
|
--sidebar-icon-size: 1rem;
|
|
}
|
|
|
|
.side-tool-bar-end {
|
|
align-self: flex-end;
|
|
margin-top: auto;
|
|
}
|
|
</style>
|