mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-04-20 22:39:39 +00:00
## Summary Updated the styling of the `resetToDefault` button to match the visual design and UX behavior (hover states, dimensions) of other buttons in the `TopBarHeader` ## Changes Applied the standard top bar button CSS classes to the resetToDefault button to ensure visual consistency. @jtydhr88 ## Review Focus Please verify that the button alignment and hover effects now match the adjacent UI elements. ## Screenshots <img width="2746" height="2300" alt="ScreenShot_2025-11-27_010713_634" src="https://github.com/user-attachments/assets/758e108f-7c38-4b51-a236-fee2e049186e" /> ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-6991-fix-ui-update-button-style-for-mask-editor-2b86d73d3650813ea3cbd28203239cd8) by [Unito](https://www.unito.io)
130 lines
3.7 KiB
Vue
130 lines
3.7 KiB
Vue
<template>
|
|
<div class="flex flex-col gap-3 pb-3">
|
|
<h3
|
|
class="text-center text-[15px] font-sans text-[var(--descrip-text)] mt-2.5"
|
|
>
|
|
{{ t('maskEditor.brushSettings') }}
|
|
</h3>
|
|
|
|
<button :class="textButtonClass" @click="resetToDefault">
|
|
{{ t('maskEditor.resetToDefault') }}
|
|
</button>
|
|
|
|
<div class="flex flex-col gap-3 pb-3">
|
|
<span class="text-left text-xs font-sans text-[var(--descrip-text)]">{{
|
|
t('maskEditor.brushShape')
|
|
}}</span>
|
|
<div
|
|
class="flex flex-row gap-2.5 items-center min-h-6 relative h-[50px] w-full rounded-[10px] bg-secondary-background-hover"
|
|
>
|
|
<div
|
|
class="maskEditor_sidePanelBrushShapeCircle bg-transparent hover:bg-comfy-menu-bg"
|
|
:class="{ active: store.brushSettings.type === BrushShape.Arc }"
|
|
:style="{
|
|
background:
|
|
store.brushSettings.type === BrushShape.Arc
|
|
? 'var(--p-button-text-primary-color)'
|
|
: ''
|
|
}"
|
|
@click="setBrushShape(BrushShape.Arc)"
|
|
></div>
|
|
<div
|
|
class="maskEditor_sidePanelBrushShapeSquare bg-transparent hover:bg-comfy-menu-bg"
|
|
:class="{ active: store.brushSettings.type === BrushShape.Rect }"
|
|
:style="{
|
|
background:
|
|
store.brushSettings.type === BrushShape.Rect
|
|
? 'var(--p-button-text-primary-color)'
|
|
: ''
|
|
}"
|
|
@click="setBrushShape(BrushShape.Rect)"
|
|
></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="flex flex-col gap-3 pb-3">
|
|
<span class="text-left text-xs font-sans text-[var(--descrip-text)]">{{
|
|
t('maskEditor.colorSelector')
|
|
}}</span>
|
|
<input type="color" :value="store.rgbColor" @input="onColorChange" />
|
|
</div>
|
|
|
|
<SliderControl
|
|
:label="t('maskEditor.thickness')"
|
|
:min="1"
|
|
:max="500"
|
|
:step="1"
|
|
:model-value="store.brushSettings.size"
|
|
@update:model-value="onThicknessChange"
|
|
/>
|
|
|
|
<SliderControl
|
|
:label="t('maskEditor.opacity')"
|
|
:min="0"
|
|
:max="1"
|
|
:step="0.01"
|
|
:model-value="store.brushSettings.opacity"
|
|
@update:model-value="onOpacityChange"
|
|
/>
|
|
|
|
<SliderControl
|
|
:label="t('maskEditor.hardness')"
|
|
:min="0"
|
|
:max="1"
|
|
:step="0.01"
|
|
:model-value="store.brushSettings.hardness"
|
|
@update:model-value="onHardnessChange"
|
|
/>
|
|
|
|
<SliderControl
|
|
:label="$t('maskEditor.stepSize')"
|
|
:min="1"
|
|
:max="100"
|
|
:step="1"
|
|
:model-value="store.brushSettings.stepSize"
|
|
@update:model-value="onStepSizeChange"
|
|
/>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { BrushShape } from '@/extensions/core/maskeditor/types'
|
|
import { t } from '@/i18n'
|
|
import { useMaskEditorStore } from '@/stores/maskEditorStore'
|
|
|
|
import SliderControl from './controls/SliderControl.vue'
|
|
|
|
const store = useMaskEditorStore()
|
|
|
|
const textButtonClass =
|
|
'h-7.5 w-32 rounded-[10px] border border-[var(--p-form-field-border-color)] text-[var(--input-text)] font-sans pointer-events-auto transition-colors duration-100 bg-[var(--comfy-menu-bg)] hover:bg-secondary-background-hover'
|
|
|
|
const setBrushShape = (shape: BrushShape) => {
|
|
store.brushSettings.type = shape
|
|
}
|
|
|
|
const onColorChange = (event: Event) => {
|
|
store.rgbColor = (event.target as HTMLInputElement).value
|
|
}
|
|
|
|
const onThicknessChange = (value: number) => {
|
|
store.setBrushSize(value)
|
|
}
|
|
|
|
const onOpacityChange = (value: number) => {
|
|
store.setBrushOpacity(value)
|
|
}
|
|
|
|
const onHardnessChange = (value: number) => {
|
|
store.setBrushHardness(value)
|
|
}
|
|
|
|
const onStepSizeChange = (value: number) => {
|
|
store.setBrushStepSize(value)
|
|
}
|
|
|
|
const resetToDefault = () => {
|
|
store.resetBrushToDefault()
|
|
}
|
|
</script>
|