Hotfix: restore cancel button in top menu (#7234)
## Summary - restore the interrupt/cancel button in the top menu action bar ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-7234-Hotfix-restore-cancel-button-in-top-menu-2c36d73d365081b18dede1e49183a429) by [Unito](https://www.unito.io) --------- Co-authored-by: github-actions <github-actions@github.com>
|
Before Width: | Height: | Size: 130 KiB After Width: | Height: | Size: 130 KiB |
|
Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 56 KiB |
|
Before Width: | Height: | Size: 36 KiB After Width: | Height: | Size: 35 KiB |
|
Before Width: | Height: | Size: 37 KiB After Width: | Height: | Size: 37 KiB |
|
Before Width: | Height: | Size: 60 KiB After Width: | Height: | Size: 61 KiB |
|
Before Width: | Height: | Size: 59 KiB After Width: | Height: | Size: 59 KiB |
|
Before Width: | Height: | Size: 60 KiB After Width: | Height: | Size: 60 KiB |
|
Before Width: | Height: | Size: 62 KiB After Width: | Height: | Size: 62 KiB |
|
Before Width: | Height: | Size: 62 KiB After Width: | Height: | Size: 62 KiB |
|
Before Width: | Height: | Size: 61 KiB After Width: | Height: | Size: 61 KiB |
|
Before Width: | Height: | Size: 58 KiB After Width: | Height: | Size: 59 KiB |
|
Before Width: | Height: | Size: 57 KiB After Width: | Height: | Size: 58 KiB |
|
Before Width: | Height: | Size: 112 KiB After Width: | Height: | Size: 112 KiB |
|
Before Width: | Height: | Size: 38 KiB After Width: | Height: | Size: 37 KiB |
|
Before Width: | Height: | Size: 123 KiB After Width: | Height: | Size: 123 KiB |
|
Before Width: | Height: | Size: 123 KiB After Width: | Height: | Size: 123 KiB |
|
Before Width: | Height: | Size: 152 KiB After Width: | Height: | Size: 152 KiB |
|
Before Width: | Height: | Size: 143 KiB After Width: | Height: | Size: 144 KiB |
|
Before Width: | Height: | Size: 122 KiB After Width: | Height: | Size: 123 KiB |
|
Before Width: | Height: | Size: 83 KiB After Width: | Height: | Size: 84 KiB |
@@ -20,6 +20,17 @@
|
|||||||
class="[&:not(:has(*>*:not(:empty)))]:hidden"
|
class="[&:not(:has(*>*:not(:empty)))]:hidden"
|
||||||
></div>
|
></div>
|
||||||
<ComfyActionbar />
|
<ComfyActionbar />
|
||||||
|
<IconButton
|
||||||
|
v-tooltip.bottom="cancelJobTooltipConfig"
|
||||||
|
type="transparent"
|
||||||
|
size="sm"
|
||||||
|
class="mr-2 bg-destructive-background text-base-foreground transition-colors duration-200 ease-in-out hover:bg-destructive-background-hover focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-destructive-background"
|
||||||
|
:disabled="isExecutionIdle"
|
||||||
|
:aria-label="t('menu.interrupt')"
|
||||||
|
@click="cancelCurrentJob"
|
||||||
|
>
|
||||||
|
<i class="icon-[lucide--x] size-4" />
|
||||||
|
</IconButton>
|
||||||
<IconButton
|
<IconButton
|
||||||
v-tooltip.bottom="queueHistoryTooltipConfig"
|
v-tooltip.bottom="queueHistoryTooltipConfig"
|
||||||
type="transparent"
|
type="transparent"
|
||||||
@@ -76,6 +87,8 @@ import LoginButton from '@/components/topbar/LoginButton.vue'
|
|||||||
import { useCurrentUser } from '@/composables/auth/useCurrentUser'
|
import { useCurrentUser } from '@/composables/auth/useCurrentUser'
|
||||||
import { buildTooltipConfig } from '@/composables/useTooltipConfig'
|
import { buildTooltipConfig } from '@/composables/useTooltipConfig'
|
||||||
import { app } from '@/scripts/app'
|
import { app } from '@/scripts/app'
|
||||||
|
import { useCommandStore } from '@/stores/commandStore'
|
||||||
|
import { useExecutionStore } from '@/stores/executionStore'
|
||||||
import { useQueueStore } from '@/stores/queueStore'
|
import { useQueueStore } from '@/stores/queueStore'
|
||||||
import { useRightSidePanelStore } from '@/stores/workspace/rightSidePanelStore'
|
import { useRightSidePanelStore } from '@/stores/workspace/rightSidePanelStore'
|
||||||
import { useWorkspaceStore } from '@/stores/workspaceStore'
|
import { useWorkspaceStore } from '@/stores/workspaceStore'
|
||||||
@@ -83,6 +96,8 @@ import { isElectron } from '@/utils/envUtil'
|
|||||||
|
|
||||||
const workspaceStore = useWorkspaceStore()
|
const workspaceStore = useWorkspaceStore()
|
||||||
const rightSidePanelStore = useRightSidePanelStore()
|
const rightSidePanelStore = useRightSidePanelStore()
|
||||||
|
const executionStore = useExecutionStore()
|
||||||
|
const commandStore = useCommandStore()
|
||||||
const { isLoggedIn } = useCurrentUser()
|
const { isLoggedIn } = useCurrentUser()
|
||||||
const isDesktop = isElectron()
|
const isDesktop = isElectron()
|
||||||
const { t } = useI18n()
|
const { t } = useI18n()
|
||||||
@@ -93,9 +108,13 @@ const queuedCount = computed(() => queueStore.pendingTasks.length)
|
|||||||
const queueHistoryTooltipConfig = computed(() =>
|
const queueHistoryTooltipConfig = computed(() =>
|
||||||
buildTooltipConfig(t('sideToolbar.queueProgressOverlay.viewJobHistory'))
|
buildTooltipConfig(t('sideToolbar.queueProgressOverlay.viewJobHistory'))
|
||||||
)
|
)
|
||||||
|
const cancelJobTooltipConfig = computed(() =>
|
||||||
|
buildTooltipConfig(t('menu.interrupt'))
|
||||||
|
)
|
||||||
|
|
||||||
// Right side panel toggle
|
// Right side panel toggle
|
||||||
const { isOpen: isRightSidePanelOpen } = storeToRefs(rightSidePanelStore)
|
const { isOpen: isRightSidePanelOpen } = storeToRefs(rightSidePanelStore)
|
||||||
|
const { isIdle: isExecutionIdle } = storeToRefs(executionStore)
|
||||||
const rightSidePanelTooltipConfig = computed(() =>
|
const rightSidePanelTooltipConfig = computed(() =>
|
||||||
buildTooltipConfig(t('rightSidePanel.togglePanel'))
|
buildTooltipConfig(t('rightSidePanel.togglePanel'))
|
||||||
)
|
)
|
||||||
@@ -112,6 +131,11 @@ onMounted(() => {
|
|||||||
const toggleQueueOverlay = () => {
|
const toggleQueueOverlay = () => {
|
||||||
isQueueOverlayExpanded.value = !isQueueOverlayExpanded.value
|
isQueueOverlayExpanded.value = !isQueueOverlayExpanded.value
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const cancelCurrentJob = async () => {
|
||||||
|
if (isExecutionIdle.value) return
|
||||||
|
await commandStore.execute('Comfy.Interrupt')
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped>
|
<style scoped>
|
||||||
|
|||||||