# Introduction closes https://github.com/twentyhq/core-team-issues/issues/591 Same than for `twenty-shared` made in https://github.com/twentyhq/twenty/pull/11083. ## TODO - [x] Manual migrate twenty-website twenty-ui imports ## What's next: - Generate barrel and migration script factorization within own package + tests - Refactoring using preconstruct ? TimeBox - Lint circular dependencies - Lint import from barrel and forbid them ### Preconstruct We need custom rollup plugins addition, but preconstruct does not expose its rollup configuration. It might be possible to handle this using the babel overrides. But was a big tunnel. We could give it a try afterwards ! ( allowing cjs interop and stuff like that ) Stuck to vite lib app Closed related PRs: - https://github.com/twentyhq/twenty/pull/11294 - https://github.com/twentyhq/twenty/pull/11203
104 lines
2.4 KiB
TypeScript
104 lines
2.4 KiB
TypeScript
import styled from '@emotion/styled';
|
|
import { ChangeEvent, useEffect, useRef, useState } from 'react';
|
|
|
|
import { LightCopyIconButton } from '@/object-record/record-field/components/LightCopyIconButton';
|
|
import { useRegisterInputEvents } from '@/object-record/record-field/meta-types/input/hooks/useRegisterInputEvents';
|
|
import { TEXT_INPUT_STYLE } from 'twenty-ui/theme';
|
|
|
|
export const StyledTextInput = styled.input`
|
|
margin: 0;
|
|
${TEXT_INPUT_STYLE}
|
|
width: 100%;
|
|
|
|
&:disabled {
|
|
color: ${({ theme }) => theme.font.color.tertiary};
|
|
}
|
|
`;
|
|
|
|
type TextInputProps = {
|
|
inputId?: string;
|
|
placeholder?: string;
|
|
autoFocus?: boolean;
|
|
value: string;
|
|
onEnter?: (newText: string) => void;
|
|
onEscape?: (newText: string) => void;
|
|
onTab?: (newText: string) => void;
|
|
onShiftTab?: (newText: string) => void;
|
|
onClickOutside?: (event: MouseEvent | TouchEvent, inputValue: string) => void;
|
|
hotkeyScope: string;
|
|
onChange?: (newText: string) => void;
|
|
copyButton?: boolean;
|
|
shouldTrim?: boolean;
|
|
disabled?: boolean;
|
|
};
|
|
|
|
const getValue = (value: string, shouldTrim: boolean) => {
|
|
if (shouldTrim) {
|
|
return value.trim();
|
|
}
|
|
|
|
return value;
|
|
};
|
|
|
|
export const TextInput = ({
|
|
inputId,
|
|
placeholder,
|
|
autoFocus,
|
|
value,
|
|
hotkeyScope,
|
|
onEnter,
|
|
onEscape,
|
|
onTab,
|
|
onShiftTab,
|
|
onClickOutside,
|
|
onChange,
|
|
copyButton = true,
|
|
shouldTrim = true,
|
|
disabled,
|
|
}: TextInputProps) => {
|
|
const [internalText, setInternalText] = useState(value);
|
|
|
|
const wrapperRef = useRef<HTMLInputElement>(null);
|
|
const copyRef = useRef<HTMLDivElement>(null);
|
|
|
|
const handleChange = (event: ChangeEvent<HTMLInputElement>) => {
|
|
setInternalText(getValue(event.target.value, shouldTrim));
|
|
onChange?.(getValue(event.target.value, shouldTrim));
|
|
};
|
|
useEffect(() => {
|
|
setInternalText(getValue(value, shouldTrim));
|
|
}, [value, shouldTrim]);
|
|
|
|
useRegisterInputEvents({
|
|
inputRef: wrapperRef,
|
|
copyRef: copyRef,
|
|
inputValue: internalText,
|
|
onEnter,
|
|
onEscape,
|
|
onClickOutside,
|
|
onTab,
|
|
onShiftTab,
|
|
hotkeyScope,
|
|
});
|
|
|
|
return (
|
|
<>
|
|
<StyledTextInput
|
|
id={inputId}
|
|
autoComplete="off"
|
|
ref={wrapperRef}
|
|
placeholder={placeholder}
|
|
onChange={handleChange}
|
|
autoFocus={autoFocus}
|
|
value={internalText}
|
|
disabled={disabled}
|
|
/>
|
|
{copyButton && (
|
|
<div ref={copyRef}>
|
|
<LightCopyIconButton copyText={internalText} />
|
|
</div>
|
|
)}
|
|
</>
|
|
);
|
|
};
|