mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-04-20 06:20:11 +00:00
## Summary Enable `better-tailwindcss/enforce-consistent-class-order` lint rule and auto-fix all 1027 violations across 263 files. Stacked on #9427. ## Changes - **What**: Sort Tailwind classes into consistent order via `eslint --fix` - Enable `enforce-consistent-class-order` as `'error'` in eslint config - Purely cosmetic reordering — no behavioral or visual changes ## Review Focus Mechanical auto-fix PR — all changes are class reordering only. This is the largest diff but lowest risk since it changes no class names, only their order. **Stack:** #9417 → #9427 → **this PR** Fixes #9300 (partial — 3 of 3 rules) ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-9428-fix-enable-enforce-consistent-class-order-tailwind-lint-rule-31a6d73d3650811c9065f5178ba3e724) by [Unito](https://www.unito.io)
83 lines
2.8 KiB
Vue
83 lines
2.8 KiB
Vue
<template>
|
|
<Popover :show-arrow="false" class="min-w-56 p-3">
|
|
<template #button>
|
|
<button
|
|
:class="
|
|
cn(
|
|
'absolute top-[calc(var(--workflow-tabs-height)+16px)] left-4 z-1000 inline-flex h-10 cursor-pointer items-center gap-2.5 rounded-lg border-none py-2 pr-2 pl-3 shadow-interface transition-colors',
|
|
'bg-secondary-background hover:bg-secondary-background-hover',
|
|
'data-[state=open]:bg-secondary-background-hover'
|
|
)
|
|
"
|
|
:aria-label="t('linearMode.appModeToolbar.appBuilder')"
|
|
>
|
|
<i class="icon-[lucide--hammer] size-4" />
|
|
<span class="text-sm font-medium">
|
|
{{ t('linearMode.appModeToolbar.appBuilder') }}
|
|
</span>
|
|
<i class="icon-[lucide--chevron-down] size-4 text-muted-foreground" />
|
|
</button>
|
|
</template>
|
|
<template #default="{ close }">
|
|
<button
|
|
:class="
|
|
cn(
|
|
'flex w-full items-center gap-3 rounded-md border-none bg-transparent px-3 py-2 text-sm',
|
|
hasOutputs
|
|
? 'cursor-pointer hover:bg-secondary-background-hover'
|
|
: 'pointer-events-none opacity-50'
|
|
)
|
|
"
|
|
:disabled="!hasOutputs"
|
|
@click="onSave(close)"
|
|
>
|
|
<i class="icon-[lucide--save] size-4" />
|
|
{{ t('g.save') }}
|
|
</button>
|
|
<div class="my-1 border-t border-border-default" />
|
|
<button
|
|
class="flex w-full cursor-pointer items-center gap-3 rounded-md border-none bg-transparent px-3 py-2 text-sm hover:bg-secondary-background-hover"
|
|
@click="onExitBuilder(close)"
|
|
>
|
|
<i class="icon-[lucide--square-pen] size-4" />
|
|
{{ t('builderMenu.exitAppBuilder') }}
|
|
</button>
|
|
</template>
|
|
</Popover>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { storeToRefs } from 'pinia'
|
|
import { useI18n } from 'vue-i18n'
|
|
|
|
import Popover from '@/components/ui/Popover.vue'
|
|
import { useErrorHandling } from '@/composables/useErrorHandling'
|
|
import { useWorkflowService } from '@/platform/workflow/core/services/workflowService'
|
|
import { useWorkflowStore } from '@/platform/workflow/management/stores/workflowStore'
|
|
import { useAppModeStore } from '@/stores/appModeStore'
|
|
import { cn } from '@/utils/tailwindUtil'
|
|
|
|
const { t } = useI18n()
|
|
const appModeStore = useAppModeStore()
|
|
const { hasOutputs } = storeToRefs(appModeStore)
|
|
const workflowService = useWorkflowService()
|
|
const workflowStore = useWorkflowStore()
|
|
const { toastErrorHandler } = useErrorHandling()
|
|
|
|
async function onSave(close: () => void) {
|
|
const workflow = workflowStore.activeWorkflow
|
|
if (!workflow) return
|
|
try {
|
|
await workflowService.saveWorkflow(workflow)
|
|
close()
|
|
} catch (error) {
|
|
toastErrorHandler(error)
|
|
}
|
|
}
|
|
|
|
function onExitBuilder(close: () => void) {
|
|
void appModeStore.exitBuilder()
|
|
close()
|
|
}
|
|
</script>
|