616058b603
- Added a new profile route under the hidden layout. - Introduced a Sidebar component for navigation between inventory, add product, and profile pages. - Created InventoryPage to display a list of products with sorting and pagination. - Implemented ViewProduct page to show details of a selected product. - Integrated API calls for fetching products and product details. - Updated route tree to include new routes and components.
94 lines
2.0 KiB
JavaScript
94 lines
2.0 KiB
JavaScript
import mysql from "mysql2";
|
|
import dotenv from "dotenv";
|
|
dotenv.config();
|
|
|
|
const pool = mysql
|
|
.createPool({
|
|
host: process.env.DB_HOST,
|
|
user: process.env.DB_USER,
|
|
password: process.env.DB_PASSWORD,
|
|
database: process.env.DB_NAME,
|
|
})
|
|
.promise();
|
|
|
|
export const newProduct = async (
|
|
name,
|
|
description,
|
|
price,
|
|
amount,
|
|
storage_location,
|
|
expiry_date,
|
|
bottling_date,
|
|
) => {
|
|
const [result] = await pool.query(
|
|
"INSERT INTO products (name, description, price, amount, storage_location, expiry_date, bottling_date) VALUES (?, ?, ?, ?, UUID_TO_BIN(?), ?, ?)",
|
|
[
|
|
name,
|
|
description,
|
|
price,
|
|
amount,
|
|
storage_location,
|
|
expiry_date,
|
|
bottling_date,
|
|
],
|
|
);
|
|
|
|
if (result.affectedRows > 0) {
|
|
return { code: "sp001" }; // success
|
|
} else {
|
|
return { code: "ep001" }; // error
|
|
}
|
|
};
|
|
|
|
export const productDetails = async (uuid) => {
|
|
const [result] = await pool.query(
|
|
`SELECT
|
|
BIN_TO_UUID(p.uuid) AS uuid,
|
|
p.name,
|
|
p.description,
|
|
p.price,
|
|
p.amount,
|
|
BIN_TO_UUID(s.uuid) AS storage_location_uuid,
|
|
s.name AS storage_location_name,
|
|
p.expiry_date,
|
|
p.bottling_date,
|
|
p.picture
|
|
FROM products p
|
|
JOIN storage_locations s ON p.storage_location = s.uuid
|
|
WHERE p.uuid = UUID_TO_BIN(?)`,
|
|
[uuid],
|
|
);
|
|
|
|
if (result.length > 0) {
|
|
return { code: "sp003", data: result[0] };
|
|
} else {
|
|
return { code: "ep003" };
|
|
}
|
|
};
|
|
|
|
export const allProducts = async () => {
|
|
const [result] = await pool.query(`
|
|
SELECT
|
|
BIN_TO_UUID(p.uuid) AS uuid,
|
|
p.name,
|
|
p.description,
|
|
p.price,
|
|
p.amount,
|
|
BIN_TO_UUID(s.uuid) AS storage_location_uuid,
|
|
s.name AS storage_location_name,
|
|
p.expiry_date,
|
|
p.bottling_date,
|
|
p.picture,
|
|
p.created_at,
|
|
p.updated_at
|
|
FROM products p
|
|
JOIN storage_locations s ON p.storage_location = s.uuid
|
|
`);
|
|
|
|
if (result.length > 0) {
|
|
return { code: "sp002", data: result };
|
|
} else {
|
|
return { code: "ep002" };
|
|
}
|
|
};
|