mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
🐛 Fixed emojis not updating in Announcement Bar (#19792)
refs https://linear.app/tryghost/issue/ENG-358/🐛-emojis-created-with-lexicals-emoji-picker-are-not-displayed - Changed the update method from onBlur to a 500ms denounce instead since the onBlur would update before the emoji plugin for the koenig editor input field manages to create the emoji. - Switching to denouncing would ensure the preview only updates once the input field stopped being modified.
This commit is contained in:
parent
2816c2c128
commit
8582462619
1 changed files with 9 additions and 13 deletions
|
@ -1,8 +1,9 @@
|
|||
import AnnouncementBarPreview from './announcementBar/AnnouncementBarPreview';
|
||||
import NiceModal from '@ebay/nice-modal-react';
|
||||
import React, {useCallback, useState} from 'react';
|
||||
import React, {useRef, useState} from 'react';
|
||||
import useSettingGroup from '../../../hooks/useSettingGroup';
|
||||
import {CheckboxGroup, ColorIndicator, Form, HtmlField, PreviewModalContent, Tab, showToast} from '@tryghost/admin-x-design-system';
|
||||
import {debounce} from '@tryghost/admin-x-design-system';
|
||||
import {getHomepageUrl} from '@tryghost/admin-x-framework/api/site';
|
||||
import {getSettingValues} from '@tryghost/admin-x-framework/api/settings';
|
||||
import {useBrowsePosts} from '@tryghost/admin-x-framework/api/posts';
|
||||
|
@ -118,7 +119,6 @@ const AnnouncementBarModal: React.FC = () => {
|
|||
const visibilitySettings = JSON.parse(announcementVisibility?.toString() || '[]') as string[];
|
||||
const {updateRoute} = useRouting();
|
||||
const [selectedPreviewTab, setSelectedPreviewTab] = useState('homepage');
|
||||
const [announcementContentState, setAnnouncementContentState] = useState(announcementContent);
|
||||
|
||||
const toggleColorSwatch = (e: string | null) => {
|
||||
updateSetting('announcement_background', e);
|
||||
|
@ -134,28 +134,24 @@ const AnnouncementBarModal: React.FC = () => {
|
|||
updateSetting('announcement_visibility', JSON.stringify(visibilitySettings));
|
||||
};
|
||||
|
||||
const announcementTextHandler = useCallback((e:string) => {
|
||||
setAnnouncementContentState(e);
|
||||
}, []);
|
||||
const updateAnnouncementDebouncedRef = useRef(
|
||||
debounce((value: string) => {
|
||||
updateSetting('announcement_content', value);
|
||||
}, 500)
|
||||
);
|
||||
|
||||
const sidebar = <Sidebar
|
||||
accentColor={accentColor}
|
||||
announcementBackgroundColor={announcementBackgroundColor}
|
||||
announcementContent={announcementContent}
|
||||
announcementTextHandler={(e) => {
|
||||
announcementTextHandler(e);
|
||||
updateAnnouncementDebouncedRef.current(e);
|
||||
}}
|
||||
paidMembersEnabled={paidMembersEnabled}
|
||||
toggleColorSwatch={toggleColorSwatch}
|
||||
toggleVisibility={toggleVisibility}
|
||||
visibility={announcementVisibility as string[]}
|
||||
onBlur={() => {
|
||||
if (announcementContentState) {
|
||||
updateSetting('announcement_content', announcementContentState);
|
||||
} else {
|
||||
updateSetting('announcement_content', null);
|
||||
}
|
||||
}}
|
||||
onBlur={() => {}}
|
||||
/>;
|
||||
|
||||
const {data: {posts: [latestPost]} = {posts: []}} = useBrowsePosts({
|
||||
|
|
Loading…
Add table
Reference in a new issue