Viewing File: /home/maglabs/marco/wp-content/plugins/extendify/src/Assist/state/Recommendations.js

import { create } from 'zustand';
import { persist, createJSONStorage } from 'zustand/middleware';
import { getRecommendationData, saveRecommendationData } from '../api/Data';

const key = 'extendify-assist-recommendations';
const startingState = {
	viewedRecommendations: [],
	dismissedRecommendations: [],
	// initialize the state with default values
	...((window.extAssistData.userData.recommendationData?.data || {})?.state ??
		{}),
};

const state = (set, get) => ({
	...startingState,
	track(slug) {
		const lastViewedAt = new Date().toISOString();
		const firstViewedAt = lastViewedAt;
		set(({ viewedRecommendations }) => {
			const viewed = viewedRecommendations.find((a) => a.slug === slug);
			return {
				viewedRecommendations: [
					// Remove if it's already in the list
					...viewedRecommendations.filter((a) => a.slug !== slug),
					// Either add it or update the count
					viewed
						? { ...viewed, count: viewed.count + 1, lastViewedAt }
						: { slug, firstViewedAt, lastViewedAt, count: 1 },
				],
			};
		});
	},
	isDismissedRecommendation(id) {
		return get().dismissedRecommendations.some((rec) => rec.id === id);
	},
	dismissRecommendation(id) {
		if (get().isDismissedRecommendation(id)) return;
		const rec = { id, dismissedAt: new Date().toISOString() };
		set((state) => ({
			dismissedRecommendations: [...state.dismissedRecommendations, rec],
		}));
	},
});

const storage = {
	getItem: async () => JSON.stringify(await getRecommendationData()),
	setItem: async (_, value) => await saveRecommendationData(value),
	removeItem: () => undefined,
};

export const useRecommendationsStore = create(
	persist(state, {
		name: key,
		storage: createJSONStorage(() => storage),
		skipHydration: true,
	}),
);
Back to Directory File Manager