export default function TokenPickerButtonLegacy()

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>
  );
}