a. Update CORS settings b. Update session cookie settings c. Remove comments that expose project architecture (and that Claude made most of it :P)
163 lines
5.8 KiB
JavaScript
163 lines
5.8 KiB
JavaScript
import DOM from './dom.js';
|
|
|
|
export default class API {
|
|
|
|
static getCsrfToken() {
|
|
return document.querySelector(idCSRFToken).getAttribute('content');
|
|
}
|
|
|
|
static async request(hashEndpoint, method = 'GET', data = null, params = null) {
|
|
const url = API.getUrlFromHash(hashEndpoint, params);
|
|
const csrfToken = API.getCsrfToken();
|
|
const options = {
|
|
method,
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
[flagCsrfToken]: csrfToken,
|
|
}
|
|
};
|
|
|
|
if (data && (method === 'POST' || method === 'PUT' || method === 'PATCH')) {
|
|
data = {
|
|
...data,
|
|
[flagCsrfToken]: csrfToken,
|
|
};
|
|
options.body = JSON.stringify(data);
|
|
}
|
|
|
|
try {
|
|
const response = await fetch(url, options);
|
|
if (!response.ok) {
|
|
throw new Error(`HTTP error! status: ${response.status}`);
|
|
}
|
|
return await response.json();
|
|
} catch (error) {
|
|
console.error('API request failed:', error);
|
|
throw error;
|
|
}
|
|
}
|
|
|
|
static getUrlFromHash(hash, params = null) {
|
|
if (hash == null) hash = hashPageHome;
|
|
let url = API.parameteriseUrl(_pathHost + hash, params);
|
|
return url;
|
|
}
|
|
static parameteriseUrl(url, params) {
|
|
if (params) {
|
|
url += '?' + new URLSearchParams(params).toString();
|
|
}
|
|
return url;
|
|
}
|
|
static goToUrl(url) {
|
|
window.location.href = url;
|
|
}
|
|
static goToHash(hash, params = null) {
|
|
const url = API.getUrlFromHash(hash, params);
|
|
API.goToUrl(url);
|
|
}
|
|
|
|
|
|
// specific api calls
|
|
/* Example:
|
|
getUsers: () => request('/users'),
|
|
getUserById: (id) => request(`/users/${id}`),
|
|
createUser: (userData) => request('/users', 'POST', userData),
|
|
updateUser: (id, userData) => request(`/users/${id}`, 'PUT', userData),
|
|
deleteUser: (id) => request(`/users/${id}`, 'DELETE'),
|
|
*/
|
|
static async loginUser() {
|
|
let callback = {};
|
|
callback[flagCallback] = DOM.getHashPageCurrent();
|
|
return await API.request(hashPageUserLogin, 'POST', callback);
|
|
}
|
|
|
|
// store
|
|
// product categories
|
|
static async saveCategories(categories, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagProductCategory] = categories;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreProductCategory, 'POST', dataRequest);
|
|
}
|
|
|
|
// products
|
|
static async saveProducts(products, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagProduct] = products;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreProduct, 'POST', dataRequest);
|
|
}
|
|
|
|
// product permutations
|
|
static async saveProductPermutations(permutations, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagProductPermutation] = permutations;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreProductPermutation, 'POST', dataRequest);
|
|
}
|
|
|
|
// product variations
|
|
static async saveProductVariations(variationTypes, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagProductVariationType] = variationTypes;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreProductVariation, 'POST', dataRequest);
|
|
}
|
|
|
|
// stock items
|
|
static async saveStockItems(stockItems, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagStockItem] = stockItems;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreStockItem, 'POST', dataRequest);
|
|
}
|
|
|
|
// suppliers
|
|
static async saveSuppliers(suppliers, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagSupplier] = suppliers;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreSupplier, 'POST', dataRequest);
|
|
}
|
|
|
|
// supplier purchase orders
|
|
static async saveSupplierPurchaseOrders(supplierPurchaseOrders, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagSupplierPurchaseOrder] = supplierPurchaseOrders;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreSupplierPurchaseOrder, 'POST', dataRequest);
|
|
}
|
|
|
|
// manufacturing purchase orders
|
|
static async saveManufacturingPurchaseOrders(manufacturingPurchaseOrders, formFilters, comment) {
|
|
let dataRequest = {};
|
|
dataRequest[flagFormFilters] = DOM.convertForm2JSON(formFilters);
|
|
dataRequest[flagManufacturingPurchaseOrder] = manufacturingPurchaseOrders;
|
|
dataRequest[flagComment] = comment;
|
|
return await API.request(hashSaveStoreManufacturingPurchaseOrder, 'POST', dataRequest);
|
|
}
|
|
}
|
|
|
|
/*
|
|
|
|
const api = new API();
|
|
export default api;
|
|
|
|
document.addEventListener('DOMContentLoaded', () => {
|
|
initializeApp();
|
|
setupEventListeners();
|
|
initializeComponents();
|
|
|
|
// Example of using the API
|
|
API.getData('/some-endpoint')
|
|
.then(data => console.log('Data received:', data))
|
|
.catch(error => console.error('Error:', error));
|
|
});
|
|
*/ |