File "use-kit-favorites-mutations.js"

Full Path: /home/warrior1/public_html/plugins/elementor/app/modules/kit-library/assets/js/hooks/use-kit-favorites-mutations.js
File size: 1.53 KB
MIME-type: text/x-java
Charset: utf-8

import { useCallback } from 'react';
import { KEY as kitsKey } from '../hooks/use-kits';
import { KEY as kitKey } from '../hooks/use-kit';
import { useMutation, useQueryClient } from 'react-query';

export function useKitFavoritesMutations() {
	const queryClient = useQueryClient();

	const onSuccess = useCallback( ( { data } ) => {
		const id = data.data.id;
		const isFavorite = data.data.is_favorite;

		// Update the kit list if the list exists.
		if ( queryClient.getQueryData( [ kitsKey ] ) ) {
			queryClient.setQueryData(
				[ kitsKey ],
				( kits ) => {
					if ( ! kits ) {
						return kits;
					}

					return kits.map( ( item ) => {
						if ( item.id === id ) {
							item.isFavorite = isFavorite;

							// Should return a new kit to trigger rerender.
							return item.clone();
						}

						return item;
					} );
				},
			);
		}

		// Update specific kit if the kit exists
		if ( queryClient.getQueryData( [ kitKey, id ] ) ) {
			queryClient.setQueryData(
				[ kitKey, id ],
				( currentKit ) => {
					currentKit.isFavorite = isFavorite;

					// Should return a new kit to trigger rerender.
					return currentKit.clone();
				},
			);
		}
	}, [ queryClient ] );

	const addToFavorites = useMutation(
		( id ) => $e.data.create( 'kits/favorites', {}, { id } ),
		{ onSuccess },
	);
	const removeFromFavorites = useMutation(
		( id ) => $e.data.delete( 'kits/favorites', { id } ),
		{ onSuccess },
	);

	return {
		addToFavorites,
		removeFromFavorites,
		isLoading: addToFavorites.isLoading || removeFromFavorites.isLoading,
	};
}