Files
masto-fe-archos/app/javascript/flavours/glitch/containers/dropdown_menu_container.js
2025-10-12 13:42:02 +02:00

39 lines
1.1 KiB
JavaScript

import { connect } from "react-redux";
import { openDropdownMenu, closeDropdownMenu } from "flavours/glitch/actions/dropdown_menu";
import { openModal, closeModal } from "flavours/glitch/actions/modal";
import DropdownMenu from "flavours/glitch/components/dropdown_menu";
import { isUserTouching } from "../is_mobile";
/**
* @param {import('flavours/glitch/store').RootState} state
*/
const mapStateToProps = state => ({
openDropdownId: state.dropdownMenu.openId,
openedViaKeyboard: state.dropdownMenu.keyboard,
});
const mapDispatchToProps = (dispatch, { status, items, scrollKey }) => ({
onOpen(id, onItemClick, keyboard) {
dispatch(isUserTouching() ? openModal({
modalType: "ACTIONS",
modalProps: {
status,
actions: items,
onClick: onItemClick,
},
}) : openDropdownMenu({ id, keyboard, scrollKey }));
},
onClose(id) {
dispatch(closeModal({
modalType: "ACTIONS",
ignoreFocus: false,
}));
dispatch(closeDropdownMenu({ id }));
},
});
export default connect(mapStateToProps, mapDispatchToProps)(DropdownMenu);