File "favorites-actions.js"

Full Path: /home/warrior1/public_html/languages/wp-content/plugins/elementor/app/modules/kit-library/assets/js/components/favorites-actions.js
File size: 1.98 KB
MIME-type: text/x-java
Charset: utf-8

import { useKitFavoritesMutations } from '../hooks/use-kit-favorites-mutations';
import { Button } from '@elementor/app-ui';
import { appsEventTrackingDispatch } from 'elementor-app/event-track/apps-event-tracking';

import './favorites-actions.scss';

export default function FavoritesActions( props ) {
	const { addToFavorites, removeFromFavorites, isLoading } = useKitFavoritesMutations();

	const loadingClasses = isLoading ? 'e-kit-library__kit-favorite-actions--loading' : '';
	const eventTracking = ( kitName, source, action, gridLocation = null, searchTerm = null ) => {
		appsEventTrackingDispatch(
			'kit-library/favorite-icon',
			{
				grid_location: gridLocation,
				search_term: searchTerm,
				kit_name: kitName,
				page_source: source && ( '/' === source ? 'home page' : 'overview' ),
				element_location: source && 'overview' === source ? 'app_sidebar' : null,
				action,
			},
		);
	};

	return (
		props.isFavorite
			? <Button
					text={ __( 'Remove from Favorites', 'elementor' ) }
					hideText={ true }
					icon="eicon-heart"
					className={ `e-kit-library__kit-favorite-actions e-kit-library__kit-favorite-actions--active ${ loadingClasses }` }
					onClick={ () => {
						// eslint-disable-next-line no-unused-expressions
						! isLoading && removeFromFavorites.mutate( props.id );
						eventTracking( props?.name, props?.source, 'uncheck' );
					} }
			/>
			: <Button
					text={ __( 'Add to Favorites', 'elementor' ) }
					hideText={ true }
					icon="eicon-heart-o"
					className={ `e-kit-library__kit-favorite-actions ${ loadingClasses }` }
					onClick={ () => {
						// eslint-disable-next-line no-unused-expressions
						! isLoading && addToFavorites.mutate( props.id );
						eventTracking( props?.name, props?.source, 'check', props?.index, props?.queryParams );
					} }
			/>
	);
}

FavoritesActions.propTypes = {
	isFavorite: PropTypes.bool,
	id: PropTypes.string,
	name: PropTypes.string,
	source: PropTypes.string,
	index: PropTypes.number,
	queryParams: PropTypes.string,
};