import React, { useState, useRef, useEffect } from 'react'; import './BulkActionsDropdown.scss'; import { translateString } from '../utils/helpers/'; import { inEmbeddedApp } from '../utils/helpers/embeddedApp'; interface BulkActionsDropdownProps { selectedCount: number; onActionSelect: (action: string) => void; hasContributorCourses?: boolean; } interface BulkAction { value: string; label: string; enabled: boolean; allowsNoSelection?: boolean; } interface BulkActionGroup { label: string; actions: BulkAction[]; } export const BulkActionsDropdown: React.FC = ({ selectedCount, onActionSelect, hasContributorCourses = false }) => { const isLmsMode = inEmbeddedApp(); const [isOpen, setIsOpen] = useState(false); const dropdownRef = useRef(null); const BULK_ACTION_GROUPS: BulkActionGroup[] = [ { label: translateString('Sharing'), actions: [ { value: 'add-remove-coviewers', label: translateString('Share with Co-Viewers'), enabled: true }, { value: 'add-remove-coeditors', label: translateString('Share with Co-Editors'), enabled: true }, { value: 'add-remove-coowners', label: translateString('Share with Co-Owners'), enabled: true }, { value: 'add-remove-category', label: isLmsMode ? translateString('Share with Course Members') : translateString('Add / Remove from Categories'), enabled: true }, ], }, { label: translateString('Organization'), actions: [ { value: 'add-remove-playlist', label: translateString('Add to / Remove from Playlist'), enabled: true }, { value: 'add-remove-tags', label: translateString('Add / Remove Tags'), enabled: true }, ], }, { label: translateString('Settings'), actions: [ { value: 'enable-comments', label: translateString('Enable Comments'), enabled: true }, { value: 'disable-comments', label: translateString('Disable Comments'), enabled: true }, { value: 'delete-comments', label: translateString('Delete Comments'), enabled: true }, { value: 'enable-download', label: translateString('Enable Download'), enabled: true }, { value: 'disable-download', label: translateString('Disable Download'), enabled: true }, ], }, { label: translateString('Management'), actions: [ { value: 'publish-state', label: translateString('Publish State'), enabled: true }, { value: 'change-owner', label: translateString('Change Owner'), enabled: true }, { value: 'copy-media', label: translateString('Copy Media'), enabled: true }, { value: 'delete-media', label: translateString('Delete Media'), enabled: true }, ...(isLmsMode && hasContributorCourses ? [{ value: 'course-cleanup', label: translateString('Course Cleanup'), enabled: true, allowsNoSelection: true }] : []), ], }, ]; const noSelection = selectedCount === 0; const displayText = noSelection ? translateString('Bulk Actions') : `${translateString('Bulk Actions')} (${selectedCount} ${translateString('selected')})`; useEffect(() => { if (!isOpen) return; const handler = (e: MouseEvent) => { if (dropdownRef.current && !dropdownRef.current.contains(e.target as Node)) { setIsOpen(false); } }; const keyHandler = (e: KeyboardEvent) => { if (e.key === 'Escape') setIsOpen(false); }; document.addEventListener('mousedown', handler); document.addEventListener('keydown', keyHandler); return () => { document.removeEventListener('mousedown', handler); document.removeEventListener('keydown', keyHandler); }; }, [isOpen]); const handleSelect = (action: BulkAction) => { const isDisabled = (!action.allowsNoSelection && noSelection) || !action.enabled; if (isDisabled) return; onActionSelect(action.value); setIsOpen(false); }; return (
{isOpen && (
{BULK_ACTION_GROUPS.map((group) => (
{group.label}
{group.actions.map((action) => { const isDisabled = (!action.allowsNoSelection && noSelection) || !action.enabled; return ( ); })}
))}
)}
); };