one-click-accessibility/modules/settings/assets/js/hooks/use-toggle-settings.js
Nirbhay Singh c084b68b5b
[APP-1292] missing mixpanel events (#245)
* add: missing mixpanel events

* update: use variable for hardcoded names

* update: use variable for hardcoded names
2025-03-24 22:31:35 +05:30

40 lines
1 KiB
JavaScript

import { useSettings } from '@ea11y/hooks';
import { eventNames, mixpanelService } from '@ea11y/services';
import { useCallback } from '@wordpress/element';
export const useToggleSetting = () => {
const { setWidgetMenuSettings, setHasChanges } = useSettings();
const toggleMenu = useCallback(
(category, option) => {
setWidgetMenuSettings((prevSettings) => {
const newSettings = {
...prevSettings,
[option]: {
...prevSettings[option],
enabled: !prevSettings[option]?.enabled,
},
};
setHasChanges(true);
if (window?.ea11yWidget?.toolsSettings && window?.ea11yWidget?.widget) {
window.ea11yWidget.toolsSettings = newSettings;
window.ea11yWidget.widget.updateState();
}
if (prevSettings[option]) {
mixpanelService.sendEvent(eventNames.toggleClicked, {
state: prevSettings[option]?.enabled ? 'off' : 'on',
type: option,
});
}
return newSettings;
});
},
[setWidgetMenuSettings, setHasChanges],
);
return { toggleMenu };
};