Skip to content

Commit e6426ea

Browse files
authored
Post editor: Require confirmation before removing Footnotes (#52277)
* Post editor: Require confirmation before removing Footnotes Context: #52176 * BlockRemovalWarningModal: Limit width to 40rem * Explain that footnotes are preserved. Add warning to Site Editor
1 parent 454452e commit e6426ea

File tree

3 files changed

+20
-1
lines changed
  • packages
    • block-editor/src/components/block-removal-warning-modal
    • edit-post/src/components/layout
    • edit-site/src/components/editor

3 files changed

+20
-1
lines changed

packages/block-editor/src/components/block-removal-warning-modal/index.js

+3
Original file line numberDiff line numberDiff line change
@@ -50,6 +50,9 @@ export function BlockRemovalWarningModal( { rules } ) {
5050
<Modal
5151
title={ __( 'Are you sure?' ) }
5252
onRequestClose={ clearBlockRemovalPrompt }
53+
style={ {
54+
maxWidth: '40rem',
55+
} }
5356
>
5457
{ blockNamesForPrompt.length === 1 ? (
5558
<p>{ rules[ blockNamesForPrompt[ 0 ] ] }</p>

packages/edit-post/src/components/layout/index.js

+14-1
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,10 @@ import {
1616
store as editorStore,
1717
} from '@wordpress/editor';
1818
import { useSelect, useDispatch } from '@wordpress/data';
19-
import { BlockBreadcrumb } from '@wordpress/block-editor';
19+
import {
20+
BlockBreadcrumb,
21+
privateApis as blockEditorPrivateApis,
22+
} from '@wordpress/block-editor';
2023
import { Button, ScrollLock, Popover } from '@wordpress/components';
2124
import { useViewportMatch } from '@wordpress/compose';
2225
import { PluginArea } from '@wordpress/plugins';
@@ -49,6 +52,9 @@ import WelcomeGuide from '../welcome-guide';
4952
import ActionsPanel from './actions-panel';
5053
import StartPageOptions from '../start-page-options';
5154
import { store as editPostStore } from '../../store';
55+
import { unlock } from '../../lock-unlock';
56+
57+
const { BlockRemovalWarningModal } = unlock( blockEditorPrivateApis );
5258

5359
const interfaceLabels = {
5460
/* translators: accessibility text for the editor top bar landmark region. */
@@ -63,6 +69,12 @@ const interfaceLabels = {
6369
footer: __( 'Editor footer' ),
6470
};
6571

72+
const blockRemovalRules = {
73+
'core/footnotes': __(
74+
'The Footnotes block displays all footnotes found in the content. Note that any footnotes in the content will persist after removing this block.'
75+
),
76+
};
77+
6678
function Layout( { styles } ) {
6779
const isMobileViewport = useViewportMatch( 'medium', '<' );
6880
const isHugeViewport = useViewportMatch( 'huge', '>=' );
@@ -202,6 +214,7 @@ function Layout( { styles } ) {
202214
<LocalAutosaveMonitor />
203215
<EditPostKeyboardShortcuts />
204216
<EditorKeyboardShortcutsRegister />
217+
<BlockRemovalWarningModal rules={ blockRemovalRules } />
205218
<SettingsSidebar />
206219
<InterfaceSkeleton
207220
isDistractionFree={ isDistractionFree && isLargeViewport }

packages/edit-site/src/components/editor/index.js

+3
Original file line numberDiff line numberDiff line change
@@ -70,6 +70,9 @@ const blockRemovalRules = {
7070
'core/post-content': __(
7171
'Post Content displays the content of a post or page.'
7272
),
73+
'core/footnotes': __(
74+
'The Footnotes block displays all footnotes found in the content. Note that any footnotes in the content will persist after removing this block.'
75+
),
7376
};
7477

7578
export default function Editor( { isLoading } ) {

0 commit comments

Comments
 (0)