mirror of
https://github.com/lemeow125/Borrowing-TrackerFrontend.git
synced 2025-01-18 23:03:11 +08:00
Refactor onClick function on transaction entry
This commit is contained in:
parent
f9b4729ee7
commit
e8864bc28c
3 changed files with 24 additions and 10 deletions
|
@ -5,8 +5,10 @@ import CircularProgress from "@mui/material/CircularProgress/CircularProgress";
|
|||
import React, { useState } from "react";
|
||||
import TransactionEntry from "../../TransactionEntry/TransactionEntry";
|
||||
import TransactionFilterMenu from "../TransactionFilterMenu";
|
||||
import { useNavigate } from "react-router-dom";
|
||||
|
||||
export default function StudentTransactionListView() {
|
||||
const navigate = useNavigate();
|
||||
const transactions = useQuery({
|
||||
queryKey: ["transactions_student"],
|
||||
queryFn: TransactionsByStudentAPI,
|
||||
|
@ -54,7 +56,15 @@ export default function StudentTransactionListView() {
|
|||
)
|
||||
.map((transaction) => (
|
||||
<React.Fragment key={transaction.id}>
|
||||
<TransactionEntry transaction={transaction} />
|
||||
<TransactionEntry
|
||||
onClick={() =>
|
||||
navigate(`/view/transaction/${transaction.id}`, {
|
||||
replace: true,
|
||||
state: { id: transaction.id },
|
||||
})
|
||||
}
|
||||
transaction={transaction}
|
||||
/>
|
||||
</React.Fragment>
|
||||
))
|
||||
) : (
|
||||
|
|
|
@ -5,8 +5,10 @@ import CircularProgress from "@mui/material/CircularProgress/CircularProgress";
|
|||
import React, { useState } from "react";
|
||||
import TransactionEntry from "../../TransactionEntry/TransactionEntry";
|
||||
import TransactionFilterMenu from "../TransactionFilterMenu";
|
||||
import { useNavigate } from "react-router-dom";
|
||||
|
||||
export default function TeacherTransactionListView() {
|
||||
const navigate = useNavigate();
|
||||
const transactions = useQuery({
|
||||
queryKey: ["transactions_teacher"],
|
||||
queryFn: TransactionsByTeacherAPI,
|
||||
|
@ -54,7 +56,15 @@ export default function TeacherTransactionListView() {
|
|||
)
|
||||
.map((transaction) => (
|
||||
<React.Fragment key={transaction.id}>
|
||||
<TransactionEntry transaction={transaction} />
|
||||
<TransactionEntry
|
||||
onClick={() =>
|
||||
navigate(`/view/transaction/${transaction.id}`, {
|
||||
replace: true,
|
||||
state: { id: transaction.id },
|
||||
})
|
||||
}
|
||||
transaction={transaction}
|
||||
/>
|
||||
</React.Fragment>
|
||||
))
|
||||
) : (
|
||||
|
|
|
@ -1,14 +1,13 @@
|
|||
import styles from "../../styles";
|
||||
import { colors } from "../../styles";
|
||||
import { TransactionType } from "../Types/Types";
|
||||
import { useNavigate } from "react-router-dom";
|
||||
import StatusTextColor from "../StatusTextColor/StatusTextColor";
|
||||
export interface props {
|
||||
transaction: TransactionType;
|
||||
onClick?: React.MouseEventHandler<HTMLButtonElement>;
|
||||
}
|
||||
|
||||
export default function TransactionEntry(props: props) {
|
||||
const navigate = useNavigate();
|
||||
return (
|
||||
<div
|
||||
style={{
|
||||
|
@ -20,12 +19,7 @@ export default function TransactionEntry(props: props) {
|
|||
margin: "8px",
|
||||
padding: "8px",
|
||||
}}
|
||||
onClick={() =>
|
||||
navigate(`/view/transaction/${props.transaction.id}`, {
|
||||
replace: true,
|
||||
state: { id: props.transaction.id },
|
||||
})
|
||||
}
|
||||
onClick={() => props.onClick}
|
||||
>
|
||||
<div style={styles.flex_row}>
|
||||
<p
|
||||
|
|
Loading…
Reference in a new issue