fix[select]: fix placeholder error when inputting Chinese (#7611)

* fix[select]: fix placeholder error when inputting Chinese

fix(selector): fix placeholder error when inputting Chinese

perf: optimize types

* Update SingleSelector.tsx

* Update index.tsx

---------

Co-authored-by: tangjinzhou <415800467@qq.com>
pull/7632/head
Carl Chen 2024-06-04 18:59:24 +08:00 committed by GitHub
parent 307148e2df
commit 6e2c5a6a83
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 20 additions and 8 deletions

View File

@ -1,7 +1,7 @@
import pickAttrs from '../../_util/pickAttrs'; import pickAttrs from '../../_util/pickAttrs';
import Input from './Input'; import Input from './Input';
import type { InnerSelectorProps } from './interface'; import type { InnerSelectorProps } from './interface';
import { Fragment, computed, defineComponent, shallowRef, watch } from 'vue'; import { Fragment, Ref, computed, defineComponent, shallowRef, watch } from 'vue';
import PropTypes from '../../_util/vue-types'; import PropTypes from '../../_util/vue-types';
import type { VueNode } from '../../_util/type'; import type { VueNode } from '../../_util/type';
import useInjectLegacySelectContext from '../../vc-tree-select/LegacyContext'; import useInjectLegacySelectContext from '../../vc-tree-select/LegacyContext';
@ -10,6 +10,9 @@ interface SelectorProps extends InnerSelectorProps {
inputElement: VueNode; inputElement: VueNode;
activeValue: string; activeValue: string;
optionLabelRender: Function; optionLabelRender: Function;
// placeholder
compositionStatus: boolean;
} }
const props = { const props = {
inputElement: PropTypes.any, inputElement: PropTypes.any,
@ -20,6 +23,7 @@ const props = {
searchValue: String, searchValue: String,
inputRef: PropTypes.any, inputRef: PropTypes.any,
placeholder: PropTypes.any, placeholder: PropTypes.any,
compositionStatus: { type: Boolean, default: undefined },
disabled: { type: Boolean, default: undefined }, disabled: { type: Boolean, default: undefined },
mode: String, mode: String,
showSearch: { type: Boolean, default: undefined }, showSearch: { type: Boolean, default: undefined },
@ -65,7 +69,9 @@ const SingleSelector = defineComponent<SelectorProps>({
// Not show text when closed expect combobox mode // Not show text when closed expect combobox mode
const hasTextInput = computed(() => const hasTextInput = computed(() =>
props.mode !== 'combobox' && !props.open && !props.showSearch ? false : !!inputValue.value, props.mode !== 'combobox' && !props.open && !props.showSearch
? false
: !!inputValue.value || props.compositionStatus,
); );
const title = computed(() => { const title = computed(() => {

View File

@ -15,7 +15,7 @@ import type { CustomTagProps, DisplayValueType, Mode, RenderNode } from '../Base
import { isValidateOpenKey } from '../utils/keyUtil'; import { isValidateOpenKey } from '../utils/keyUtil';
import useLock from '../hooks/useLock'; import useLock from '../hooks/useLock';
import type { PropType } from 'vue'; import type { PropType } from 'vue';
import { defineComponent } from 'vue'; import { defineComponent, ref } from 'vue';
import createRef from '../../_util/createRef'; import createRef from '../../_util/createRef';
import PropTypes from '../../_util/vue-types'; import PropTypes from '../../_util/vue-types';
import type { VueNode } from '../../_util/type'; import type { VueNode } from '../../_util/type';
@ -124,7 +124,7 @@ const Selector = defineComponent<SelectorProps>({
} as any, } as any,
setup(props, { expose }) { setup(props, { expose }) {
const inputRef = createRef(); const inputRef = createRef();
let compositionStatus = false; let compositionStatus = ref(false);
// ====================== Input ====================== // ====================== Input ======================
const [getInputMouseDown, setInputMouseDown] = useLock(0); const [getInputMouseDown, setInputMouseDown] = useLock(0);
@ -140,7 +140,12 @@ const Selector = defineComponent<SelectorProps>({
props.onInputKeyDown(event); props.onInputKeyDown(event);
} }
if (which === KeyCode.ENTER && props.mode === 'tags' && !compositionStatus && !props.open) { if (
which === KeyCode.ENTER &&
props.mode === 'tags' &&
!compositionStatus.value &&
!props.open
) {
// When menu isn't open, OptionList won't trigger a value change // When menu isn't open, OptionList won't trigger a value change
// So when enter is pressed, the tag's input value should be emitted here to let selector know // So when enter is pressed, the tag's input value should be emitted here to let selector know
props.onSearchSubmit((event.target as HTMLInputElement).value); props.onSearchSubmit((event.target as HTMLInputElement).value);
@ -163,17 +168,17 @@ const Selector = defineComponent<SelectorProps>({
let pastedText = null; let pastedText = null;
const triggerOnSearch = (value: string) => { const triggerOnSearch = (value: string) => {
if (props.onSearch(value, true, compositionStatus) !== false) { if (props.onSearch(value, true, compositionStatus.value) !== false) {
props.onToggleOpen(true); props.onToggleOpen(true);
} }
}; };
const onInputCompositionStart = () => { const onInputCompositionStart = () => {
compositionStatus = true; compositionStatus.value = true;
}; };
const onInputCompositionEnd = (e: InputEvent) => { const onInputCompositionEnd = (e: InputEvent) => {
compositionStatus = false; compositionStatus.value = false;
// Trigger search again to support `tokenSeparators` with typewriting // Trigger search again to support `tokenSeparators` with typewriting
if (props.mode !== 'combobox') { if (props.mode !== 'combobox') {
triggerOnSearch((e.target as HTMLInputElement).value); triggerOnSearch((e.target as HTMLInputElement).value);
@ -251,6 +256,7 @@ const Selector = defineComponent<SelectorProps>({
onInputMouseDown: onInternalInputMouseDown, onInputMouseDown: onInternalInputMouseDown,
onInputChange, onInputChange,
onInputPaste, onInputPaste,
compositionStatus: compositionStatus.value,
onInputCompositionStart, onInputCompositionStart,
onInputCompositionEnd, onInputCompositionEnd,
}; };