mirror of
https://gh.wpcy.net/https://github.com/elementor/one-click-accessibility.git
synced 2026-04-23 23:22:51 +08:00
* [APP-1513] add disconnected msg * [APP-1513] add disconnected msg * [APP-1513] add disconnected msg
109 lines
2.9 KiB
JavaScript
109 lines
2.9 KiB
JavaScript
import Alert from '@elementor/ui/Alert';
|
||
import AlertAction from '@elementor/ui/AlertAction';
|
||
import AlertTitle from '@elementor/ui/AlertTitle';
|
||
import { useSettings } from '@ea11y/hooks';
|
||
import { GOLINKS } from '@ea11y-apps/global/constants';
|
||
import { mixpanelEvents, mixpanelService } from '@ea11y-apps/global/services';
|
||
import { __ } from '@wordpress/i18n';
|
||
import { openLink } from '../utils';
|
||
|
||
const QuotaNotices = () => {
|
||
const { planUsage } = useSettings();
|
||
|
||
/**
|
||
* Handle the click on the upgrade button.
|
||
* @param {string} type
|
||
*/
|
||
const handleUpgradeClick = (type) => {
|
||
mixpanelService.sendEvent(mixpanelEvents.upgradeButtonClicked, {
|
||
feature: 'quota notice ' + type,
|
||
component: 'upgrade button',
|
||
});
|
||
openLink(GOLINKS[`UPGRADE_${type}`]);
|
||
};
|
||
|
||
/**
|
||
* Send an event to Mixpanel when the quota notice is triggered.
|
||
* @param {string} type
|
||
*/
|
||
const sendQuotaNoticeTriggeredEvent = (type) => {
|
||
mixpanelService.sendEvent('quota_notice_triggered', {
|
||
quota_level: type,
|
||
});
|
||
};
|
||
|
||
if (planUsage < 80) {
|
||
return null;
|
||
}
|
||
|
||
if (planUsage >= 80 && planUsage < 95) {
|
||
sendQuotaNoticeTriggeredEvent('80%');
|
||
return (
|
||
<Alert severity="warning" square>
|
||
<AlertTitle>
|
||
{__(
|
||
'You’ve reached 80% of your monthly plan usage',
|
||
'pojo-accessibility',
|
||
)}
|
||
</AlertTitle>
|
||
{__(
|
||
'Upgrade now to increase your limit and ensure all accessibility features stay fully available for every visitor.',
|
||
'pojo-accessibility',
|
||
)}
|
||
<AlertAction
|
||
variant="outlined"
|
||
onClick={() => handleUpgradeClick('80')}
|
||
sx={{ marginTop: 1 }}
|
||
>
|
||
{__('Upgrade now', 'pojo-accessibility')}
|
||
</AlertAction>
|
||
</Alert>
|
||
);
|
||
}
|
||
|
||
if (planUsage >= 95 && planUsage < 100) {
|
||
sendQuotaNoticeTriggeredEvent('95%');
|
||
return (
|
||
<Alert severity="error" square>
|
||
<AlertTitle>
|
||
{__('Only 5% of your monthly plan usage left', 'pojo-accessibility')}
|
||
</AlertTitle>
|
||
{__(
|
||
'Upgrade now to increase your limit and keep all accessibility features running smoothly for every visitor.',
|
||
'pojo-accessibility',
|
||
)}
|
||
<AlertAction
|
||
variant="outlined"
|
||
onClick={() => handleUpgradeClick('95')}
|
||
sx={{ marginTop: 1 }}
|
||
>
|
||
{__('Upgrade now', 'pojo-accessibility')}
|
||
</AlertAction>
|
||
</Alert>
|
||
);
|
||
}
|
||
|
||
if (planUsage === 100) {
|
||
sendQuotaNoticeTriggeredEvent('100%');
|
||
return (
|
||
<Alert severity="error" square>
|
||
<AlertTitle>
|
||
{__("You've reached your monthly plan usage", 'pojo-accessibility')}
|
||
</AlertTitle>
|
||
{__(
|
||
'Upgrade now to raise your limit and maintain complete access to all accessibility features for every visitor.',
|
||
'pojo-accessibility',
|
||
)}
|
||
<AlertAction
|
||
variant="outlined"
|
||
onClick={() => handleUpgradeClick('100')}
|
||
sx={{ marginTop: 1 }}
|
||
>
|
||
{__('Upgrade now', 'pojo-accessibility')}
|
||
</AlertAction>
|
||
</Alert>
|
||
);
|
||
}
|
||
};
|
||
|
||
export default QuotaNotices;
|