Server IP : 162.213.251.212 / Your IP : 18.218.150.40 [ Web Server : LiteSpeed System : Linux business55.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : allssztx ( 535) PHP Version : 8.1.31 Disable Function : NONE Domains : 1 Domains MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/allssztx/public_html/jollyprecast/wp-content/plugins/extendify/src/Shared/lib/ |
Upload File : |
import { AI_HOST } from '@constants'; import { useAIConsentStore } from '@shared/state/ai-consent'; import { useUnsplashCacheStore } from '@shared/state/unsplash-cache'; const { showAIConsent, userGaveConsent } = useAIConsentStore.getState(); // Additional data to send with requests const allowList = [ 'siteId', 'partnerId', 'wpVersion', 'wpLanguage', 'devbuild', 'isBlockTheme', 'userId', ]; const extraBody = { ...Object.fromEntries( Object.entries(window.extSharedData).filter(([key]) => allowList.includes(key), ), ), showAIConsent, userGaveConsent, }; export const fetchImages = async (search) => { const queryString = new URLSearchParams({ ...extraBody, query: search, }); const res = await fetch( `${AI_HOST}/api/draft/image/unsplash?${queryString.toString()}`, { method: 'GET', headers: { 'Content-Type': 'application/json' }, }, ); if (!res.ok) { throw new Error('Bad response from server'); } const images = await res.json(); if (!Array.isArray(images)) { throw new Error('Bad response from server'); } const result = images.map((image) => ({ ...image, requestMetadata: { id: res.headers.get('X-Request-Id'), total: res.headers.get('X-Total'), perPage: res.headers.get('X-Per-Page'), }, })); return result; }; export const preFetchImages = async () => { const cache = useUnsplashCacheStore.getState(); if (!cache.isEmpty() && !cache.hasExpired()) { return cache.images; } const { aiKeywords } = window.extSharedData?.siteProfile ?? {}; const queries = aiKeywords?.length ? aiKeywords : []; const images = (await Promise.all(queries.map(fetchImages))).flat(); const uniqueImagesMap = images.reduce((acc, image) => { if (!acc.has(image.id)) { acc.set(image.id, image); } return acc; }, new Map()); cache.updateCache(Array.from(uniqueImagesMap.values())); return images; };