in libs/designer-ui/src/lib/editor/base/plugins/TokenPickerButtonLegacy.tsx [27:116]
export default function TokenPickerButtonLegacy({
showTokenPicker,
buttonClassName,
buttonOffset,
labelId,
customButton,
setShowTokenPicker,
codeEditor,
}: ButtonProps): JSX.Element {
let editor: LexicalEditor | null;
try {
[editor] = useLexicalComposerContext();
} catch {
editor = null;
}
useEffect(() => {
if (editor && !editor.hasNodes([TokenNode])) {
throw new Error('TokenPlugin: Register the TokenNode on editor');
}
}, [editor]);
const intl = useIntl();
const addContent = intl.formatMessage({
defaultMessage: 'Add dynamic content',
id: '3BZnxY',
description: 'Label for button to open token picker',
});
const addContentAltTextShow = intl.formatMessage({
defaultMessage: 'Button to add dynamic content if token picker is shown',
id: 'TZpm7X',
description: 'Text for if image does not show up',
});
const addContentAltTextHide = intl.formatMessage({
defaultMessage: 'Button to add dynamic content if token picker is hidden',
id: 'fNE/hg',
description: 'Text for if image does not show up',
});
const handleClick = () => {
if (showTokenPicker && codeEditor) {
codeEditor.focus();
}
setShowTokenPicker?.();
if (editor) {
editor.focus();
}
};
const dynamicContentButtonText = intl.formatMessage({
defaultMessage: 'Insert data from previous step (you can also add by typing Alt + / in the editor)',
id: 'wXLEcJ',
description: 'Label for button to open dynamic content token picker',
});
return (
<TooltipHost content={dynamicContentButtonText}>
<button
id={labelId}
className={`msla-tokenpicker-button ${buttonClassName}`}
data-automation-id="msla-tokenpicker-button"
onClick={() => {
handleClick();
}}
onMouseDown={(e) => e.preventDefault()}
style={
customButton
? { bottom: '-1px', right: '-5px' }
: { top: `${buttonOffset?.heightOffset}px`, right: `${buttonOffset?.widthOffset}px` }
}
>
{customButton ? null : <p className="msla-tokenpicker-button-text">{addContent}</p>}
{showTokenPicker ? (
<img
src=""
height="13px"
alt={addContentAltTextShow}
/>
) : (
<img
src=""
height="13"
alt={addContentAltTextHide}
/>
)}
</button>
</TooltipHost>
);
}