feat(api): implement bulk categorization and suggestion endpoints with authentication
refactor(actions): remove unused imports and console logs from product actions refactor(EditProductForm): update category suggestion logic to use new API endpoint
This commit is contained in:
@@ -61,7 +61,6 @@ export async function setProductTags(productId: number, tags: string[]) {
|
||||
|
||||
export async function updateProductWithTags(formData: FormData, tags: string[]) {
|
||||
const id = Number(formData.get('id'));
|
||||
console.log('[actions:updateProductWithTags] called for product id:', id, 'tags:', tags);
|
||||
const name = String(formData.get('name') || '').trim();
|
||||
const canonicalName = String(formData.get('canonicalName') || '').trim();
|
||||
const category = String(formData.get('category') || '').trim();
|
||||
@@ -78,7 +77,6 @@ export async function updateProductWithTags(formData: FormData, tags: string[])
|
||||
if (brand.length > 100) throw new Error('Varumärke får inte vara längre än 100 tecken.');
|
||||
|
||||
const authHeaders = await getAuthHeaders();
|
||||
console.log('[actions:updateProductWithTags] auth headers present:', !!authHeaders.Authorization);
|
||||
const res = await fetch(`${API_BASE}/api/products/${id}`, {
|
||||
method: 'PATCH',
|
||||
headers: { 'Content-Type': 'application/json', ...authHeaders },
|
||||
@@ -99,7 +97,6 @@ export async function updateProductWithTags(formData: FormData, tags: string[])
|
||||
}
|
||||
|
||||
const updatedProduct = await res.json();
|
||||
console.log('[actions:updateProductWithTags] PATCH OK, product id:', (updatedProduct as any)?.id);
|
||||
|
||||
const tagsRes = await fetch(`${API_BASE}/api/products/${id}/tags`, {
|
||||
method: 'PUT',
|
||||
@@ -113,16 +110,13 @@ export async function updateProductWithTags(formData: FormData, tags: string[])
|
||||
throw new Error(`Kunde inte uppdatera taggar: ${text}`);
|
||||
}
|
||||
|
||||
console.log('[actions:updateProductWithTags] tags PUT OK, fetching full product...');
|
||||
// Fetch the complete product (includes tags, categoryRef) after both updates
|
||||
// Fetch the complete product
|
||||
const fullRes = await fetch(`${API_BASE}/api/products/${id}`, {
|
||||
headers: authHeaders,
|
||||
cache: 'no-store',
|
||||
});
|
||||
console.log('[actions:updateProductWithTags] full product fetch HTTP', fullRes.status);
|
||||
if (!fullRes.ok) return updatedProduct;
|
||||
const result = await fullRes.json();
|
||||
console.log('[actions:updateProductWithTags] returning full product id:', (result as any)?.id);
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user