woocommerce/plugins/woocommerce-admin/client/wc-api/items/operations.js

101 lines
2.5 KiB
JavaScript
Raw Normal View History

/** @format */
/**
* External dependencies
*/
import apiFetch from '@wordpress/api-fetch';
/**
* WooCommerce dependencies
*/
import { stringifyQuery } from '@woocommerce/navigation';
/**
* Internal dependencies
*/
import { getResourceIdentifier, getResourcePrefix, getResourceName } from '../utils';
import { NAMESPACE } from '../constants';
const typeEndpointMap = {
'items-query-categories': 'products/categories',
'items-query-customers': 'customers',
'items-query-coupons': 'coupons',
'items-query-orders': 'orders',
'items-query-products': 'products',
'items-query-taxes': 'taxes',
};
function read( resourceNames, fetch = apiFetch ) {
const filteredNames = resourceNames.filter( name => {
const prefix = getResourcePrefix( name );
return Boolean( typeEndpointMap[ prefix ] );
} );
return filteredNames.map( async resourceName => {
const prefix = getResourcePrefix( resourceName );
const endpoint = typeEndpointMap[ prefix ];
const query = getResourceIdentifier( resourceName );
const url = NAMESPACE + `/${ endpoint }${ stringifyQuery( query ) }`;
try {
const response = await fetch( {
parse: false,
path: url,
} );
const items = await response.json();
const ids = items.map( item => item.id );
const totalCount = parseInt( response.headers.get( 'x-wp-total' ) );
const itemResources = items.reduce( ( resources, item ) => {
resources[ getResourceName( `${ prefix }-item`, item.id ) ] = { data: item };
return resources;
}, {} );
return {
[ resourceName ]: {
data: ids,
totalCount,
},
...itemResources,
};
} catch ( error ) {
return { [ resourceName ]: { error } };
}
} );
}
function update( resourceNames, data, fetch = apiFetch ) {
console.log( 'update', resourceNames, data );
const updateableTypes = [ 'product', 'variation' ];
const filteredNames = resourceNames.filter( name => {
return updateableTypes.includes( name );
} );
return filteredNames.map( async resourceName => {
const { id, parent_id, ...itemData } = data[ resourceName ];
let url = NAMESPACE;
switch ( resourceName ) {
case 'variation':
url += `/products/${ parent_id }/variations/${ id }`;
break;
case 'product':
default:
url += `/products/${ id }`;
}
return fetch( { path: url, method: 'PUT', data: itemData } )
.then( item => {
return { [ resourceName + ':' + id ]: { data: item } };
} )
.catch( error => {
return { [ resourceName + ':' + id ]: { error } };
} );
} );
}
export default {
read,
update,
};