
META-INF.resources.page_editor.app.components.ToolbarActionsDropdown.js Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.liferay.layout.content.page.editor.web
Show all versions of com.liferay.layout.content.page.editor.web
Liferay Layout Content Page Editor Web
The newest version!
/**
* SPDX-FileCopyrightText: (c) 2000 Liferay, Inc. https://liferay.com
* SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
*/
import {ClayButtonWithIcon} from '@clayui/button';
import {ClayDropDownWithItems} from '@clayui/drop-down';
import React from 'react';
import {useSelectMultipleItems} from '../contexts/ControlsContext';
import {useSelector} from '../contexts/StoreContext';
import {onDiscardDraft} from './DiscardDraftButton';
import {useDisabledRedo, useDisabledUndo} from './undo/Undo';
import {useHistoryItems, useOnHistoryItemClick} from './undo/UndoHistory';
import UndoOverlay from './undo/UndoOverlay';
import useUndoRedoActions from './undo/useUndoRedoActions';
import useDisabledDiscardDraft from './useDisabledDiscardDraft';
import useOnToggleSidebars from './useOnToggleSidebars';
export default function ToolbarActionsDropdown({discardDraftFormRef}) {
const disabledDiscardDraft = useDisabledDiscardDraft();
const disabledRedo = useDisabledRedo();
const disabledUndo = useDisabledUndo();
const historyItems = useHistoryItems();
const {loadingHistory, onHistoryItemClick} = useOnHistoryItemClick();
const {onRedo, onUndo} = useUndoRedoActions();
const onToggleSidebars = useOnToggleSidebars();
const selectMultipleItems = useSelectMultipleItems();
const sidebarHidden = useSelector((state) => state.sidebar.hidden);
const undoHistory = useSelector((state) => state.undoHistory);
const selectItems = selectMultipleItems;
return (
<>
{loadingHistory && }
onUndo({selectItems}),
symbolLeft: 'undo',
},
{
disabled: disabledRedo,
label: Liferay.Language.get('redo'),
onClick: () => onRedo({selectItems}),
symbolLeft: 'redo',
},
{
disabled: !historyItems.length,
items: historyItems.length
? [
...historyItems,
{type: 'divider'},
{
disabled: !undoHistory.length,
label: Liferay.Language.get('undo-all'),
onClick: onHistoryItemClick,
},
]
: null,
label: Liferay.Language.get('history'),
symbolLeft: 'time',
type: 'contextual',
},
{type: 'divider'},
{
label: sidebarHidden
? Liferay.Language.get('show-sidebars')
: Liferay.Language.get('hide-sidebars'),
onClick: onToggleSidebars,
symbolLeft: 'view',
},
{type: 'divider'},
{
disabled: disabledDiscardDraft,
label: Liferay.Language.get('discard-draft'),
onClick: (event) =>
onDiscardDraft(event, discardDraftFormRef.current),
},
]}
trigger={
}
/>
>
);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy