feat(ui): add setting for always show image size badge

This commit is contained in:
psychedelicious 2024-03-12 18:49:55 +11:00
parent cc03fcbcb6
commit 43948e0758
5 changed files with 20 additions and 1 deletions

View File

@ -398,6 +398,7 @@
},
"gallery": {
"allImagesLoaded": "All Images Loaded",
"alwaysShowImageSizeBadge": "Always Show Image Size Badge",
"assets": "Assets",
"autoAssignBoardOnClick": "Auto-Assign Board on Click",
"autoSwitchNewImages": "Auto-Switch to New Images",

View File

@ -15,6 +15,7 @@ import {
} from '@invoke-ai/ui-library';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import {
alwaysShowImageSizeBadgeChanged,
autoAssignBoardOnClickChanged,
setGalleryImageMinimumWidth,
shouldAutoSwitchChanged,
@ -36,6 +37,7 @@ const GallerySettingsPopover = () => {
const galleryImageMinimumWidth = useAppSelector((s) => s.gallery.galleryImageMinimumWidth);
const shouldAutoSwitch = useAppSelector((s) => s.gallery.shouldAutoSwitch);
const autoAssignBoardOnClick = useAppSelector((s) => s.gallery.autoAssignBoardOnClick);
const alwaysShowImageSizeBadge = useAppSelector((s) => s.gallery.alwaysShowImageSizeBadge);
const handleChangeGalleryImageMinimumWidth = useCallback(
(v: number) => {
@ -56,6 +58,11 @@ const GallerySettingsPopover = () => {
[dispatch]
);
const handleChangeAlwaysShowImageSizeBadgeChanged = useCallback(
(e: ChangeEvent<HTMLInputElement>) => dispatch(alwaysShowImageSizeBadgeChanged(e.target.checked)),
[dispatch]
);
return (
<Popover isLazy>
<PopoverTrigger>
@ -88,6 +95,10 @@ const GallerySettingsPopover = () => {
<FormLabel>{t('gallery.autoAssignBoardOnClick')}</FormLabel>
<Checkbox isChecked={autoAssignBoardOnClick} onChange={handleChangeAutoAssignBoardOnClick} />
</FormControl>
<FormControl>
<FormLabel>{t('gallery.alwaysShowImageSizeBadge')}</FormLabel>
<Checkbox isChecked={alwaysShowImageSizeBadge} onChange={handleChangeAlwaysShowImageSizeBadgeChanged} />
</FormControl>
</FormControlGroup>
<BoardAutoAddSelect />
</Flex>

View File

@ -44,6 +44,7 @@ const GalleryImage = (props: HoverableImageProps) => {
const shift = useShiftModifier();
const { t } = useTranslation();
const selectedBoardId = useAppSelector((s) => s.gallery.selectedBoardId);
const alwaysShowImageSizeBadge = useAppSelector((s) => s.gallery.alwaysShowImageSizeBadge);
const { handleClick, isSelected, areMultiplesSelected } = useMultiselect(imageDTO);
const customStarUi = useStore($customStarUI);
@ -155,7 +156,7 @@ const GalleryImage = (props: HoverableImageProps) => {
onMouseOut={handleMouseOut}
>
<>
{isHovered && (
{(isHovered || alwaysShowImageSizeBadge) && (
<Text
position="absolute"
background="base.900"

View File

@ -15,6 +15,7 @@ const initialGalleryState: GalleryState = {
autoAssignBoardOnClick: true,
autoAddBoardId: 'none',
galleryImageMinimumWidth: 90,
alwaysShowImageSizeBadge: false,
selectedBoardId: 'none',
galleryView: 'images',
boardSearchText: '',
@ -71,6 +72,9 @@ export const gallerySlice = createSlice({
state.limit += IMAGE_LIMIT;
}
},
alwaysShowImageSizeBadgeChanged: (state, action: PayloadAction<boolean>) => {
state.alwaysShowImageSizeBadge = action.payload;
},
},
extraReducers: (builder) => {
builder.addMatcher(isAnyBoardDeleted, (state, action) => {
@ -107,6 +111,7 @@ export const {
selectionChanged,
boardSearchTextChanged,
moreImagesLoaded,
alwaysShowImageSizeBadgeChanged,
} = gallerySlice.actions;
const isAnyBoardDeleted = isAnyOf(

View File

@ -19,4 +19,5 @@ export type GalleryState = {
boardSearchText: string;
offset: number;
limit: number;
alwaysShowImageSizeBadge: boolean;
};