import { AI_HOST } from '@constants';
import apiFetch from '@wordpress/api-fetch';
import { addQueryArgs } from '@wordpress/url';
export const getPlugin = async (slug) => {
const response = await apiFetch({
path: addQueryArgs('/wp/v2/plugins', { search: slug }),
const plugin = response?.[0];
if (!plugin) throw new Error('Plugin not found');
export const getAllPlugins = async () => {
const response = await apiFetch({
throw new Error('Failed to fetch installed plugins');
export const installPlugin = async (slug) => {
export const activatePlugin = async (slug) => {
const plugin = await getPlugin(slug);
path: `/wp/v2/plugins/${plugin.plugin}`,
export const loadImage = (img) => {
return new Promise((resolve, reject) => {
img.onload = () => resolve(img);
img.onerror = (e) => reject(e);
export const importImage = async (imageUrl, metadata = {}) => {
const image = new Image();
image.crossOrigin = 'anonymous';
const canvas = document.createElement('canvas');
canvas.width = image.width;
canvas.height = image.height;
const ctx = canvas.getContext('2d');
ctx.drawImage(image, 0, 0);
const blob = await new Promise((resolve) => {
canvas.toBlob((blob) => {
const formData = new FormData();
formData.append('file', new File([blob], metadata.filename));
formData.append('alt_text', metadata.alt ?? '');
formData.append('caption', metadata.caption ?? '');
formData.append('status', 'publish');
export const importImageServer = async (src, metadata = {}) => {
const formData = new FormData();
formData.append('source', src);
// Fallback doesn't support custom file_name
formData.append('alt_text', metadata.alt ?? '');
formData.append('caption', metadata.caption ?? '');
path: '/extendify/v1/draft/upload-image',
export const downloadImage = async (
metadata = { alt: '', caption: '' },
await downloadPing(id, source, { unsplashId });
image = await importImage(src, {
caption: metadata.caption,
image = await importImageServer(src, {
caption: metadata.caption,
export const downloadPing = (id, source, details = {}) =>
fetch(`${AI_HOST}/api/draft/image/download`, {
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ id, source, ...details }),