mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Fixed reply-to dropdown when custom address was set (#19197)
fixes GRO-103 When a custom reply-to address was set using one of the new flags, and those flags were disabled - the dropdown showed an empty value and saving was broken because of this value. This change automatically reverts back to 'newsletter' as a default value when editing a newsletter with an invalid reply-to value.
This commit is contained in:
parent
4d029c4812
commit
c07218dff4
1 changed files with 13 additions and 3 deletions
|
@ -1,6 +1,6 @@
|
||||||
import NewsletterPreview from './NewsletterPreview';
|
import NewsletterPreview from './NewsletterPreview';
|
||||||
import NiceModal, {useModal} from '@ebay/nice-modal-react';
|
import NiceModal, {useModal} from '@ebay/nice-modal-react';
|
||||||
import React, {useEffect, useState} from 'react';
|
import React, {useEffect, useMemo, useState} from 'react';
|
||||||
import useFeatureFlag from '../../../../hooks/useFeatureFlag';
|
import useFeatureFlag from '../../../../hooks/useFeatureFlag';
|
||||||
import useSettingGroup from '../../../../hooks/useSettingGroup';
|
import useSettingGroup from '../../../../hooks/useSettingGroup';
|
||||||
import validator from 'validator';
|
import validator from 'validator';
|
||||||
|
@ -37,10 +37,10 @@ const Sidebar: React.FC<{
|
||||||
|
|
||||||
let newsletterAddress = renderSenderEmail(newsletter, config, defaultEmailAddress);
|
let newsletterAddress = renderSenderEmail(newsletter, config, defaultEmailAddress);
|
||||||
|
|
||||||
const replyToEmails = [
|
const replyToEmails = useMemo(() => [
|
||||||
{label: `Newsletter address (${newsletterAddress})`, value: 'newsletter'},
|
{label: `Newsletter address (${newsletterAddress})`, value: 'newsletter'},
|
||||||
{label: `Support address (${supportEmailAddress})`, value: 'support'}
|
{label: `Support address (${supportEmailAddress})`, value: 'support'}
|
||||||
];
|
], [newsletterAddress, supportEmailAddress]);
|
||||||
|
|
||||||
const fontOptions: SelectOption[] = [
|
const fontOptions: SelectOption[] = [
|
||||||
{value: 'serif', label: 'Elegant serif', className: 'font-serif'},
|
{value: 'serif', label: 'Elegant serif', className: 'font-serif'},
|
||||||
|
@ -176,6 +176,16 @@ const Sidebar: React.FC<{
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (!isManagedEmail(config)) {
|
||||||
|
// Autocorrect invalid values
|
||||||
|
const foundValue = replyToEmails.find(option => option.value === newsletter.sender_reply_to);
|
||||||
|
if (!foundValue) {
|
||||||
|
updateNewsletter({sender_reply_to: 'newsletter'});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, [config, replyToEmails, updateNewsletter, newsletter.sender_reply_to]);
|
||||||
|
|
||||||
const renderReplyToEmailField = () => {
|
const renderReplyToEmailField = () => {
|
||||||
// Self-hosters, or legacy Pro users
|
// Self-hosters, or legacy Pro users
|
||||||
if (!isManagedEmail(config)) {
|
if (!isManagedEmail(config)) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue