110 lines
3.5 KiB
JavaScript
Raw Normal View History

2023-11-10 14:23:55 +04:00
// модуль для работы с REST API сервера
// адрес сервера
const serverUrl = 'http://localhost:8081';
// функция возвращает объект нужной структуры для отправки на сервер
// eslint-disable-next-line require-jsdoc
2023-11-21 16:11:09 +04:00
function createLineObject(item, name_book, author, price, isbn, image, text) {
2023-11-10 14:23:55 +04:00
return {
itemsId: item,
2023-11-21 16:11:09 +04:00
name_book,
2023-11-20 23:03:27 +04:00
author,
2023-11-21 16:11:09 +04:00
isbn,
2023-11-20 23:03:27 +04:00
price: parseFloat(price).toFixed(2),
2023-11-10 14:23:55 +04:00
image,
2023-11-21 16:11:09 +04:00
text,
2023-11-10 14:23:55 +04:00
};
}
// обращение к серверу для получения всех типов товара (get)
// eslint-disable-next-line require-jsdoc
export async function getAllItemTypes() {
const response = await fetch(`${serverUrl}/items`);
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для получения всех записей (get)
// eslint-disable-next-line require-jsdoc
export async function getAllLines() {
const response = await fetch(`${serverUrl}/lines?_expand=items`);
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для получения записи по первичному ключу (id) (get)
// id передается в качестве части пути URL get-запроса
// eslint-disable-next-line require-jsdoc
export async function getLine(id) {
const response = await fetch(`${serverUrl}/lines/${id}?_expand=items`);
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для создания записи (post)
// объект отправляется в теле запроса (body)
// eslint-disable-next-line require-jsdoc
2023-11-21 16:11:09 +04:00
export async function createLine(item, name_book, author, price, isbn, image, text) {
const itemObject = createLineObject(item, name_book, author, price, isbn, image, text);
2023-11-10 14:23:55 +04:00
const options = {
method: 'POST',
body: JSON.stringify(itemObject),
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json',
},
};
const response = await fetch(`${serverUrl}/lines`, options);
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для обновления записи по id (put)
// объект отправляется в теле запроса (body)
// id передается в качестве части пути URL get-запроса
// eslint-disable-next-line require-jsdoc
2023-11-21 16:11:09 +04:00
export async function updateLine(id, item, name_book, author, price, isbn, image, text) {
const itemObject = createLineObject(item, name_book, author, price, isbn, image, text);
2023-11-10 14:23:55 +04:00
const options = {
method: 'PUT',
body: JSON.stringify(itemObject),
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json',
},
};
const response = await fetch(`${serverUrl}/lines/${id}`, options);
if (!response.ok) {
throw response.statusText;
}
return response.json();
}
// обращение к серверу для удаления записи по id (delete)
// id передается в качестве части пути URL get-запроса
// eslint-disable-next-line require-jsdoc
export async function deleteLine(id) {
const options = {
method: 'DELETE',
};
const response = await fetch(`${serverUrl}/lines/${id}`, options);
if (!response.ok) {
throw response.statusText;
}
return response.json();
}