Added daily view page

This commit is contained in:
keannu125 2023-03-12 11:43:42 +08:00
parent a0a05e2df3
commit b7e91c345f
5 changed files with 97 additions and 70 deletions

20
package-lock.json generated
View file

@ -28,6 +28,7 @@
"react": "^18.2.0", "react": "^18.2.0",
"react-dom": "^18.2.0", "react-dom": "^18.2.0",
"react-fast-marquee": "^1.3.5", "react-fast-marquee": "^1.3.5",
"react-moment": "^1.1.3",
"react-query": "^3.39.3", "react-query": "^3.39.3",
"react-redux": "^8.0.5", "react-redux": "^8.0.5",
"react-router-dom": "^6.8.1", "react-router-dom": "^6.8.1",
@ -12592,6 +12593,15 @@
"mkdirp": "bin/cmd.js" "mkdirp": "bin/cmd.js"
} }
}, },
"node_modules/moment": {
"version": "2.29.4",
"resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz",
"integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==",
"peer": true,
"engines": {
"node": "*"
}
},
"node_modules/ms": { "node_modules/ms": {
"version": "2.1.2", "version": "2.1.2",
"resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
@ -14881,6 +14891,16 @@
"resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz",
"integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==" "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w=="
}, },
"node_modules/react-moment": {
"version": "1.1.3",
"resolved": "https://registry.npmjs.org/react-moment/-/react-moment-1.1.3.tgz",
"integrity": "sha512-8EPvlUL8u6EknPp1ISF5MQ3wx2OHJVXIP/iZc4wRh3iV3XozftZERDv9ANZeAtMlhNNQHdFoqcZHFUkBSTONfA==",
"peerDependencies": {
"moment": "^2.29.0",
"prop-types": "^15.7.0",
"react": "^16.0 || ^17.0.0 || ^18.0.0"
}
},
"node_modules/react-query": { "node_modules/react-query": {
"version": "3.39.3", "version": "3.39.3",
"resolved": "https://registry.npmjs.org/react-query/-/react-query-3.39.3.tgz", "resolved": "https://registry.npmjs.org/react-query/-/react-query-3.39.3.tgz",

View file

@ -24,6 +24,7 @@
"react": "^18.2.0", "react": "^18.2.0",
"react-dom": "^18.2.0", "react-dom": "^18.2.0",
"react-fast-marquee": "^1.3.5", "react-fast-marquee": "^1.3.5",
"react-moment": "^1.1.3",
"react-query": "^3.39.3", "react-query": "^3.39.3",
"react-redux": "^8.0.5", "react-redux": "^8.0.5",
"react-router-dom": "^6.8.1", "react-router-dom": "^6.8.1",

View file

@ -8,11 +8,14 @@ import {
} from "../../Interfaces/Interfaces"; } from "../../Interfaces/Interfaces";
// Product APIs // Product APIs
const instance = axios.create({
baseURL: "https://keannu125.pythonanywhere.com",
});
export function GetProducts() { export function GetProducts() {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.get("https://keannu125.pythonanywhere.com/api/v1/products/", { .get("api/v1/products/", {
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
@ -24,8 +27,8 @@ export function GetProducts() {
export function GetProduct(id: number) { export function GetProduct(id: number) {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.get("https://keannu125.pythonanywhere.com/api/v1/products/" + id + "/", { .get("api/v1/products/" + id + "/", {
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
@ -37,18 +40,12 @@ export function GetProduct(id: number) {
export function UpdateProduct(product: UpdateProductParams) { export function UpdateProduct(product: UpdateProductParams) {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.patch( .patch("api/v1/products/" + product.id + "/", product, {
"https://keannu125.pythonanywhere.com/api/v1/products/" +
product.id +
"/",
product,
{
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
} })
)
.then((response) => { .then((response) => {
console.log("Product update successful"); console.log("Product update successful");
return response.data; return response.data;
@ -61,8 +58,8 @@ export function UpdateProduct(product: UpdateProductParams) {
export function GetLowestStockedProduct() { export function GetLowestStockedProduct() {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.get("https://keannu125.pythonanywhere.com/api/v1/lowest_stock_product/", { .get("api/v1/lowest_stock_product/", {
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
@ -74,8 +71,8 @@ export function GetLowestStockedProduct() {
export function GetLogs() { export function GetLogs() {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.get("https://keannu125.pythonanywhere.com/api/v1/logs/", { .get("api/v1/logs/", {
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
@ -87,8 +84,8 @@ export function GetLogs() {
export function AddProduct(note: AddProductParams) { export function AddProduct(note: AddProductParams) {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.post("https://keannu125.pythonanywhere.com/api/v1/products/", note, { .post("api/v1/products/", note, {
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
@ -104,15 +101,12 @@ export function AddProduct(note: AddProductParams) {
export function DeleteProduct(id: number) { export function DeleteProduct(id: number) {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.delete( .delete("api/v1/products/" + id + "/", {
"https://keannu125.pythonanywhere.com/api/v1/products/" + id + "/",
{
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
} })
)
.catch((error) => { .catch((error) => {
console.log("Error deleting product"); console.log("Error deleting product");
return error; return error;
@ -122,11 +116,8 @@ export function DeleteProduct(id: number) {
// User APIs // User APIs
export function UserRegister(register: RegistrationParams) { export function UserRegister(register: RegistrationParams) {
return axios return instance
.post( .post("api/v1/accounts/users/", register)
"https://keannu125.pythonanywhere.com/api/v1/accounts/users/",
register
)
.then(async (response) => { .then(async (response) => {
console.log(response.data); console.log(response.data);
return true; return true;
@ -138,11 +129,8 @@ export function UserRegister(register: RegistrationParams) {
} }
export function UserLogin(user: LoginParams) { export function UserLogin(user: LoginParams) {
return axios return instance
.post( .post("api/v1/accounts/token/login/", user)
"https://keannu125.pythonanywhere.com/api/v1/accounts/token/login/",
user
)
.then(async (response) => { .then(async (response) => {
localStorage.setItem("token", JSON.stringify(response.data.auth_token)); localStorage.setItem("token", JSON.stringify(response.data.auth_token));
console.log("Login Success "); console.log("Login Success ");
@ -156,8 +144,8 @@ export function UserLogin(user: LoginParams) {
export function UserInfo() { export function UserInfo() {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.get("https://keannu125.pythonanywhere.com/api/v1/accounts/users/me/", { .get("api/v1/accounts/users/me/", {
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
@ -174,8 +162,8 @@ export function UserInfo() {
export function QueryUser(id: number) { export function QueryUser(id: number) {
const token = JSON.parse(localStorage.getItem("token") || "{}"); const token = JSON.parse(localStorage.getItem("token") || "{}");
return axios return instance
.get("https://keannu125.pythonanywhere.com/api/v1/user_list/" + id, { .get("api/v1/user_list/" + id, {
headers: { headers: {
Authorization: "Token " + token, Authorization: "Token " + token,
}, },
@ -191,11 +179,8 @@ export function QueryUser(id: number) {
} }
export function UserActivate(activation: ActivationParams) { export function UserActivate(activation: ActivationParams) {
return axios return instance
.post( .post("api/v1/accounts/users/activation/", activation)
"https://keannu125.pythonanywhere.com/api/v1/accounts/users/activation/",
activation
)
.then(async (response) => { .then(async (response) => {
console.log("Activation Success"); console.log("Activation Success");
return true; return true;

View file

@ -7,6 +7,12 @@ export interface Product {
name: string; name: string;
date_added: string; date_added: string;
quantity: number; quantity: number;
history: ProductHistoryEntry[];
}
export interface ProductHistoryEntry {
quantity: number;
history_date: string;
} }
export interface ProductLogList { export interface ProductLogList {

View file

@ -1,13 +1,6 @@
import React, { useState } from "react"; import React from "react";
import TotalProductsIcon from "../../Components/Icons/TotalProductsIcon/TotalProductsIcon";
import LowStockIcon from "../../Components/Icons/LowStockIcon/LowStockIcon";
import StatsIcon from "../../Components/Icons/StatsIcon/StatsIcon";
import LogsIcon from "../../Components/Icons/LogsIcon/LogsIcon";
import "../../index.css"; import "../../index.css";
import styles from "../../styles"; import styles from "../../styles";
import HomeIcon from "../../Components/Icons/HomeIcon/HomeIcon";
import ColoredCube from "../../Components/ColoredCube/ColoredCube";
import RecentlyAddedIcon from "../../Components/Icons/RecentlyAddedIcon/RecentlyAddedIcon";
import LoginChecker from "../../Components/LoginChecker/LoginChecker"; import LoginChecker from "../../Components/LoginChecker/LoginChecker";
import { useQuery } from "react-query"; import { useQuery } from "react-query";
import { import {
@ -15,17 +8,14 @@ import {
GetLowestStockedProduct, GetLowestStockedProduct,
GetProducts, GetProducts,
} from "../../Components/Api/Api"; } from "../../Components/Api/Api";
import { import { OldSessionState, Product } from "../../Interfaces/Interfaces";
OldSessionState,
ProductLog,
SessionTransactions,
} from "../../Interfaces/Interfaces";
import { useSelector } from "react-redux"; import { useSelector } from "react-redux";
import LowestStockWidget from "../../Components/DashboardPage/LowestStockWidget/LowestStockWidget";
import RecentlyAddedWidget from "../../Components/DashboardPage/RecentlyAddedWidget/RecentlyAddedWidget";
import TotalProductsWidget from "../../Components/DashboardPage/TotalProductsWidget/TotalProductsWidget";
import SessionStatsWidget from "../../Components/DashboardPage/SessionStatsWidget/SessionStatsWidget";
import TodayIcon from "../../Components/Icons/TodayIcon/TodayIcon"; import TodayIcon from "../../Components/Icons/TodayIcon/TodayIcon";
import moment from "moment";
import GetToday from "../../Components/GetToday/GetToday";
import Moment from "react-moment";
import { useNavigate } from "react-router-dom";
import { Button } from "@mui/material";
export default function DailyView() { export default function DailyView() {
const logs = useQuery("logs", GetLogs, { retry: 0 }); const logs = useQuery("logs", GetLogs, { retry: 0 });
@ -40,6 +30,7 @@ export default function DailyView() {
const old_session_checked = useSelector( const old_session_checked = useSelector(
(state: OldSessionState) => state.old_session_checked.value (state: OldSessionState) => state.old_session_checked.value
); );
const navigate = useNavigate();
if ( if (
logs.isLoading || logs.isLoading ||
products.isLoading || products.isLoading ||
@ -80,10 +71,34 @@ export default function DailyView() {
<LoginChecker /> <LoginChecker />
<div style={styles.flex_row}> <div style={styles.flex_row}>
<TodayIcon size={64} color="white" /> <TodayIcon size={64} color="white" />
<p style={{ ...styles.text_white, ...styles.text_XL }}>Daily View</p> <p style={{ ...styles.text_white, ...styles.text_XL }}>
Products Modified Today
</p>
</div> </div>
<div style={styles.content_row}> <div style={styles.content_column}>
<p style={{ ...styles.text_white, ...styles.text_XL }}>Heh</p> {products.data
.filter(
(Product: Product) =>
moment(Product.history[0].history_date).format("MM-DD-YYYY") ===
GetToday()
)
.map((Product: Product) => (
<button
style={{ ...styles.widget, ...{ border: "None" } }}
onClick={() => navigate("/Product/" + Product.id)}
>
<p style={{ ...styles.text_white, ...styles.text_XL }}>
Product: {Product.name}
</p>
<p style={{ ...styles.text_white, ...styles.text_XL }}>
Last Modified:{" "}
<Moment date={Product.history[0].history_date} fromNow />
</p>
<p style={{ ...styles.text_white, ...styles.text_XL }}>
Current Stock: {Product.history[0].quantity}
</p>
</button>
))}
</div> </div>
</div> </div>
); );