HEX
Server: Apache
System: Linux efa57bbe-abb1-400d-2985-3b056fbc2701.secureserver.net 6.1.147-1.el9.elrepo.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Jul 24 12:33:32 EDT 2025 x86_64
User: root (0)
PHP: 8.0.30.4
Disabled: NONE
Upload Files
File: /var/www/wp-content/plugins/pojo-accessibility/modules/settings/assets/js/layouts/quota-bar.js
import { CalendarDollarIcon } from '@elementor/icons';
import Box from '@elementor/ui/Box';
import IconButton from '@elementor/ui/IconButton';
import Skeleton from '@elementor/ui/Skeleton';
import { styled } from '@elementor/ui/styles';
import {
	bindMenu,
	bindTrigger,
	usePopupState,
} from '@elementor/ui/usePopupState';
import {
	QuotaBarGroup,
	QuotaBarPopupMenu,
	QuotaIndicator,
} from '@ea11y/components';
import { useSavedSettings, useSettings } from '@ea11y/hooks';

const QuotaBar = () => {
	const { openSidebar } = useSettings();
	const { loading } = useSavedSettings();

	const quotaPopupMenuState = usePopupState({
		variant: 'popover',
		popupId: 'quotaPopupMenu',
	});

	if (loading) {
		return (
			<StyledBox>
				<Skeleton width="100%" height={91} />
			</StyledBox>
		);
	}

	if (!openSidebar) {
		return (
			<StyledBox>
				<StyledIconButton {...bindTrigger(quotaPopupMenuState)}>
					<CalendarDollarIcon sx={{ color: 'common.black', marginRight: 1 }} />
					<QuotaIndicator />
				</StyledIconButton>
				<QuotaBarPopupMenu
					{...bindMenu(quotaPopupMenuState)}
					closeAction={quotaPopupMenuState.close}
				/>
			</StyledBox>
		);
	}

	return <QuotaBarGroup />;
};

export default QuotaBar;

const StyledBox = styled(Box)`
	display: flex;
	flex-direction: row;
	align-items: start;
	justify-content: center;

	margin: ${({ theme }) => theme.spacing(2)};
	padding: 0;

	border-radius: ${({ theme }) => theme.shape.borderRadius * 2}px;
`;

const StyledIconButton = styled(IconButton)`
	padding: ${({ theme }) => theme.spacing(1)} ${({ theme }) => theme.spacing(2)};
	background-color: ${({ theme }) => theme.palette.background.paper};
	border-radius: 8px;

	&:hover {
		background-color: ${({ theme }) => theme.palette.action.hover};
	}
`;