From ce553924615d62a24170747168b3225f088e5fc2 Mon Sep 17 00:00:00 2001 From: DingDongSoLong4 <99329275+DingDongSoLong4@users.noreply.github.com> Date: Mon, 25 Sep 2023 03:55:36 +0200 Subject: [PATCH] PerformerSelect Tagger bugfixes (#4148) * Fix Tagger PerformerSelect active highlight * Clear select on skip * Add back react-select className --- .../components/Performers/PerformerSelect.tsx | 8 +++++ ui/v2.5/src/components/Performers/styles.scss | 2 +- .../src/components/Shared/FilterSelect.tsx | 6 ++-- .../Shared/ScrapeDialog/ScrapedObjectsRow.tsx | 2 +- .../Tagger/scenes/PerformerResult.tsx | 32 +++++++++---------- ui/v2.5/src/components/Tagger/styles.scss | 20 ++++++------ 6 files changed, 39 insertions(+), 31 deletions(-) diff --git a/ui/v2.5/src/components/Performers/PerformerSelect.tsx b/ui/v2.5/src/components/Performers/PerformerSelect.tsx index c721d652deb..de1cf6771a9 100644 --- a/ui/v2.5/src/components/Performers/PerformerSelect.tsx +++ b/ui/v2.5/src/components/Performers/PerformerSelect.tsx @@ -5,6 +5,7 @@ import { MultiValueGenericProps, SingleValueProps, } from "react-select"; +import cx from "classnames"; import * as GQL from "src/core/generated-graphql"; import { @@ -170,6 +171,13 @@ export const PerformerSelect: React.FC< return ( {...props} + className={cx( + "performer-select", + { + "performer-select-active": props.active, + }, + props.className + )} loadOptions={loadPerformers} getNamedObject={getNamedObject} isValidNewOption={isValidNewOption} diff --git a/ui/v2.5/src/components/Performers/styles.scss b/ui/v2.5/src/components/Performers/styles.scss index 4451728043b..f2d23372551 100644 --- a/ui/v2.5/src/components/Performers/styles.scss +++ b/ui/v2.5/src/components/Performers/styles.scss @@ -224,6 +224,6 @@ } } -.react-select .alias { +.performer-select .alias { font-weight: bold; } diff --git a/ui/v2.5/src/components/Shared/FilterSelect.tsx b/ui/v2.5/src/components/Shared/FilterSelect.tsx index 3489f1851d4..730aa7ec22a 100644 --- a/ui/v2.5/src/components/Shared/FilterSelect.tsx +++ b/ui/v2.5/src/components/Shared/FilterSelect.tsx @@ -10,6 +10,7 @@ import AsyncSelect from "react-select/async"; import AsyncCreatableSelect, { AsyncCreatableProps, } from "react-select/async-creatable"; +import cx from "classnames"; import { useToast } from "src/hooks/Toast"; import { useDebounce } from "src/hooks/debounce"; @@ -88,8 +89,8 @@ const SelectComponent = ( ...props, styles, defaultOptions: true, - value: selectedOptions, - className: "react-select", + value: selectedOptions ?? null, + className: cx("react-select", props.className), classNamePrefix: "react-select", noOptionsMessage: () => noOptionsMessage, placeholder: isDisabled ? "" : placeholder, @@ -119,6 +120,7 @@ export interface IFilterValueProps { export interface IFilterProps { noSelectionString?: string; className?: string; + active?: boolean; isMulti?: boolean; isClearable?: boolean; isDisabled?: boolean; diff --git a/ui/v2.5/src/components/Shared/ScrapeDialog/ScrapedObjectsRow.tsx b/ui/v2.5/src/components/Shared/ScrapeDialog/ScrapedObjectsRow.tsx index 606821c789d..05c1d75ad50 100644 --- a/ui/v2.5/src/components/Shared/ScrapeDialog/ScrapedObjectsRow.tsx +++ b/ui/v2.5/src/components/Shared/ScrapeDialog/ScrapedObjectsRow.tsx @@ -147,7 +147,7 @@ export const ScrapedPerformersRow: React.FC< return ( { if (onChangeFn) { diff --git a/ui/v2.5/src/components/Tagger/scenes/PerformerResult.tsx b/ui/v2.5/src/components/Tagger/scenes/PerformerResult.tsx index 19f072c4418..6afbc442730 100755 --- a/ui/v2.5/src/components/Tagger/scenes/PerformerResult.tsx +++ b/ui/v2.5/src/components/Tagger/scenes/PerformerResult.tsx @@ -1,7 +1,6 @@ import React, { useEffect, useState } from "react"; import { Button, ButtonGroup } from "react-bootstrap"; import { FormattedMessage } from "react-intl"; -import cx from "classnames"; import * as GQL from "src/core/generated-graphql"; import { Icon } from "src/components/Shared/Icon"; @@ -43,9 +42,12 @@ const PerformerResult: React.FC = ({ stashID.stash_id === performer.remote_site_id ); - const [selectedPerformer, setSelectedPerformer] = useState< - Performer | undefined - >(); + const [selectedPerformer, setSelectedPerformer] = useState(); + + function selectPerformer(selected: Performer | undefined) { + setSelectedPerformer(selected); + setSelectedID(selected?.id); + } useEffect(() => { if ( @@ -56,18 +58,16 @@ const PerformerResult: React.FC = ({ } }, [performerData?.findPerformer, selectedID]); - const handlePerformerSelect = (performers: Performer[]) => { + const handleSelect = (performers: Performer[]) => { if (performers.length) { - setSelectedPerformer(performers[0]); - setSelectedID(performers[0].id); + selectPerformer(performers[0]); } else { - setSelectedPerformer(undefined); - setSelectedID(undefined); + selectPerformer(undefined); } }; - const handlePerformerSkip = () => { - setSelectedID(undefined); + const handleSkip = () => { + selectPerformer(undefined); }; if (stashLoading) return
Loading performer
; @@ -83,7 +83,7 @@ const PerformerResult: React.FC = ({ - v ? handlePerformerSkip() : setSelectedID(matchedPerformer.id) + v ? handleSkip() : setSelectedID(matchedPerformer.id) } >
@@ -127,16 +127,14 @@ const PerformerResult: React.FC = ({ {maybeRenderLinkButton()} diff --git a/ui/v2.5/src/components/Tagger/styles.scss b/ui/v2.5/src/components/Tagger/styles.scss index b40ce167cc1..c54d939bfa7 100644 --- a/ui/v2.5/src/components/Tagger/styles.scss +++ b/ui/v2.5/src/components/Tagger/styles.scss @@ -66,6 +66,16 @@ background-color: hsl(204, 20%, 30%); cursor: pointer; } + + .performer-select, + .studio-select { + width: 14rem; + + // stylelint-disable-next-line selector-class-pattern + &-active .react-select__control { + background-color: #137cbd; + } + } } .selected-result { @@ -98,16 +108,6 @@ width: 2rem; } -.performer-select, -.studio-select { - width: 14rem; - - // stylelint-disable-next-line selector-class-pattern - &-active .react-select__control { - background-color: #137cbd; - } -} - .entity-name { flex: 1; margin-right: auto;