@@ -11,9 +17,9 @@ const TopBar = memo(({ searchValue, searchOnChange, searchSubmit }) => (
id='search'
name='search'
autoComplete='off'
- placeholder='Aranacak kelime'
- onChange={searchOnChange}
value={searchValue}
+ onChange={searchOnChange}
+ placeholder='Aranacak kelime'
/>
-));
-
-TopBar.propTypes = {
- searchValue: PropTypes.string.isRequired,
- searchSubmit: PropTypes.func.isRequired,
- searchOnChange: PropTypes.func.isRequired,
-};
+);
export default TopBar;
diff --git a/src/components/Tables/Transactions/Amount.js b/src/components/Tables/Transactions/Amount.js
deleted file mode 100644
index baf1b53..0000000
--- a/src/components/Tables/Transactions/Amount.js
+++ /dev/null
@@ -1,17 +0,0 @@
-import { memo } from 'react';
-import PropTypes from 'prop-types';
-
-const Amount = memo(({ type, amount }) => {
- if (type === 1) {
- return
{amount};
- }
-
- return
{amount};
-});
-
-Amount.propTypes = {
- type: PropTypes.number.isRequired,
- amount: PropTypes.string.isRequired,
-};
-
-export default Amount;
diff --git a/src/components/Tables/Transactions/Amount.tsx b/src/components/Tables/Transactions/Amount.tsx
new file mode 100644
index 0000000..577eb41
--- /dev/null
+++ b/src/components/Tables/Transactions/Amount.tsx
@@ -0,0 +1,17 @@
+import React from 'react';
+
+// interfaces
+interface IProps {
+ type: number;
+ amount: string;
+}
+
+const Amount = ({ type, amount }: IProps): React.JSX.Element => {
+ if (type === 1) {
+ return
{amount};
+ }
+
+ return
{amount};
+};
+
+export default Amount;
diff --git a/src/components/Tables/Transactions/Icon.js b/src/components/Tables/Transactions/Icon.tsx
similarity index 65%
rename from src/components/Tables/Transactions/Icon.js
rename to src/components/Tables/Transactions/Icon.tsx
index c1cfc48..5787753 100644
--- a/src/components/Tables/Transactions/Icon.js
+++ b/src/components/Tables/Transactions/Icon.tsx
@@ -1,7 +1,11 @@
-import { memo } from 'react';
-import PropTypes from 'prop-types';
+import React from 'react';
-const Icon = memo(({ type }) => {
+// interfaces
+interface IProps {
+ type: number;
+}
+
+const Icon = ({ type }: IProps): React.JSX.Element => {
if (type === 1) {
return (
@@ -15,10 +19,6 @@ const Icon = memo(({ type }) => {
arrow_downward
);
-});
-
-Icon.propTypes = {
- type: PropTypes.number.isRequired,
};
export default Icon;
diff --git a/src/components/Tables/Transactions/Status.js b/src/components/Tables/Transactions/Status.tsx
similarity index 60%
rename from src/components/Tables/Transactions/Status.js
rename to src/components/Tables/Transactions/Status.tsx
index 08aabca..842dad5 100644
--- a/src/components/Tables/Transactions/Status.js
+++ b/src/components/Tables/Transactions/Status.tsx
@@ -1,7 +1,11 @@
-import { memo } from 'react';
-import PropTypes from 'prop-types';
+import React from 'react';
-const Status = memo(({ status }) => {
+// interfaces
+interface IProps {
+ status: number;
+}
+
+const Status = ({ status }: IProps): React.JSX.Element => {
if (status === 1) {
return
BİTMİŞ;
}
@@ -11,10 +15,6 @@ const Status = memo(({ status }) => {
}
return
BEKLİYOR;
-});
-
-Status.propTypes = {
- status: PropTypes.number.isRequired,
};
export default Status;
diff --git a/src/components/Tables/Transactions/TransactionRow.js b/src/components/Tables/Transactions/TransactionRow.tsx
similarity index 78%
rename from src/components/Tables/Transactions/TransactionRow.js
rename to src/components/Tables/Transactions/TransactionRow.tsx
index 312060b..0c738a8 100644
--- a/src/components/Tables/Transactions/TransactionRow.js
+++ b/src/components/Tables/Transactions/TransactionRow.tsx
@@ -1,11 +1,16 @@
-import { memo } from 'react';
-import PropTypes from 'prop-types';
+import React from 'react';
+// components
import Icon from './Icon';
import Amount from './Amount';
import Status from './Status';
-const TransactionRow = memo(({ item }) => (
+// interfaces
+interface IProps {
+ item: any;
+}
+
+const TransactionRow = ({ item }: IProps): React.JSX.Element => (
@@ -28,11 +33,6 @@ const TransactionRow = memo(({ item }) => (
|
-));
-
-TransactionRow.propTypes = {
- // eslint-disable-next-line react/forbid-prop-types
- item: PropTypes.object.isRequired,
-};
+);
export default TransactionRow;
diff --git a/src/components/Widgets/BankProcess/BankProcess.js b/src/components/Widgets/BankProcess/BankProcess.js
deleted file mode 100644
index 42d0ea7..0000000
--- a/src/components/Widgets/BankProcess/BankProcess.js
+++ /dev/null
@@ -1,166 +0,0 @@
-import { memo, useState, useEffect } from 'react';
-
-import Box from '../../Common/Box';
-
-const BankProcess = memo(() => {
- const [tab, setTab] = useState(0);
- const [bankDetails, setBankDetails] = useState([]);
- const [selectedBank, setSelectedBank] = useState(1);
-
- useEffect(() => {
- const dataArray = [
- {
- id: 1,
- name: 'Ziraat Bankası',
- branch: 'Ataşehir Şubesi',
- iban: 'TR01 0000 0000 0000 0000 0000 01',
- logo: 'https://mekaskablo.com/wp-content/uploads/2019/11/ziraat-bankas%C4%B1-logo.jpg',
- },
- {
- id: 2,
- name: 'Garanti Bankası',
- branch: 'Etiler Şubesi',
- iban: 'TR02 0000 0000 0000 0000 0000 02',
- logo: 'https://upload.wikimedia.org/wikipedia/tr/7/75/Garanti_BBVA.png',
- },
- {
- id: 3,
- name: 'Yapı ve Kredi Bankası',
- branch: 'Şişli Şubesi',
- iban: 'TR03 0000 0000 0000 0000 0000 03',
- logo: '',
- },
- ];
-
- setBankDetails(dataArray);
-
- setSelectedBank(dataArray[0]);
- }, []);
-
- const handleViewOnChange = (e) => {
- e.preventDefault();
-
- const { value } = e.target;
-
- const findBank = bankDetails.find((item) => item.id === +value);
-
- setSelectedBank(findBank);
- };
-
- return (
-
-
-
-
-
- -
-
-
- -
-
-
-
-
-
- {tab === 0 && (
-
-
-
-
- {selectedBank && (
- <>
-
-
![Bank logo]({selectedBank.logo})
-
-
- {selectedBank.name} - {selectedBank.branch}
-
-
- {selectedBank.iban}
-
-
-
- >
- )}
-
-
- )}
-
- {tab === 1 && (
-
-
-
-
-
-
-
- TR00 0000 0000 0000 0000 0000 00
-
-
- Çekilecek tutar :
- 2376.00 TL
-
-
-
-
-
- )}
-
- );
-});
-
-export default BankProcess;
diff --git a/src/components/Widgets/BankProcess/BankProcess.tsx b/src/components/Widgets/BankProcess/BankProcess.tsx
new file mode 100644
index 0000000..1a4f243
--- /dev/null
+++ b/src/components/Widgets/BankProcess/BankProcess.tsx
@@ -0,0 +1,186 @@
+import React from 'react';
+
+// components
+import Box from '../../Common/Box';
+
+// interfaces
+interface IBankDetails {
+ id: number;
+ name: string;
+ iban: string;
+ logo: string;
+ branch: string;
+}
+
+// variables
+const dataArray: IBankDetails[] = [
+ {
+ id: 1,
+ name: 'Ziraat Bankası',
+ branch: 'Ataşehir Şubesi',
+ iban: 'TR01 0000 0000 0000 0000 0000 01',
+ logo: 'https://mekaskablo.com/wp-content/uploads/2019/11/ziraat-bankas%C4%B1-logo.jpg',
+ },
+ {
+ id: 2,
+ name: 'Garanti Bankası',
+ branch: 'Etiler Şubesi',
+ iban: 'TR02 0000 0000 0000 0000 0000 02',
+ logo: 'https://upload.wikimedia.org/wikipedia/tr/7/75/Garanti_BBVA.png',
+ },
+ {
+ id: 3,
+ name: 'Yapı ve Kredi Bankası',
+ branch: 'Şişli Şubesi',
+ iban: 'TR03 0000 0000 0000 0000 0000 03',
+ logo: '',
+ },
+];
+
+const BankProcess = () => {
+ const [tab, setTab] = React.useState
(0);
+ const [bankDetails, setBankDetails] = React.useState([]);
+ const [selectedBank, setSelectedBank] = React.useState(null);
+
+ React.useEffect(() => {
+ setBankDetails(dataArray);
+
+ setSelectedBank(dataArray[0]);
+ }, []);
+
+ /**
+ * Handles the change event for the bank selection dropdown.
+ * Prevents the default event behavior, extracts the value from the target element,
+ * finds the corresponding bank details based on the value, and updates the selected bank state.
+ *
+ * @param {React.ChangeEvent} e - The change event object.
+ */
+ const handleViewOnChange = (e: React.ChangeEvent): void => {
+ e.preventDefault();
+
+ const { value } = e.target;
+
+ const findBank = bankDetails.find((item: IBankDetails) => item.id === +value);
+
+ if (findBank) {
+ setSelectedBank(findBank);
+ }
+ };
+
+ return (
+
+
+
+
+
+ -
+
+
+ -
+
+
+
+
+
+ {tab === 0 && (
+
+
+
+
+ {selectedBank && (
+ <>
+
+
![Bank logo]({selectedBank.logo})
+
+
+ {selectedBank.name} - {selectedBank.branch}
+
+
+ {selectedBank.iban}
+
+
+
+ >
+ )}
+
+
+ )}
+
+ {tab === 1 && (
+
+
+
+
+
+
+
+ TR00 0000 0000 0000 0000 0000 00
+
+
+ Çekilecek tutar :
+ 2376.00 TL
+
+
+
+
+
+ )}
+
+ );
+};
+
+export default BankProcess;
diff --git a/src/components/Widgets/BuyOrders/BuyOrders.js b/src/components/Widgets/BuyOrders/BuyOrders.tsx
similarity index 54%
rename from src/components/Widgets/BuyOrders/BuyOrders.js
rename to src/components/Widgets/BuyOrders/BuyOrders.tsx
index 5c24164..5fd0469 100644
--- a/src/components/Widgets/BuyOrders/BuyOrders.js
+++ b/src/components/Widgets/BuyOrders/BuyOrders.tsx
@@ -1,92 +1,107 @@
-import { memo, useState, useEffect } from 'react';
+import React from 'react';
+// components
import Box from '../../Common/Box';
import BuyOrdersRow from './BuyOrdersRow';
-const BuyOrders = memo(() => {
- const [data, setData] = useState([]);
- const [menuOpened, setMenuOpened] = useState(false);
+// interfaces
+interface IPriceList {
+ id: number;
+ type: number;
+ price: string;
+ total: string;
+ amount: string;
+ currency: string;
+}
- useEffect(() => {
- const dataArray = [
- {
- id: 1,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 1,
- },
- {
- id: 2,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 1,
- },
- {
- id: 3,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 3,
- },
- {
- id: 4,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 3,
- },
- {
- id: 5,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 2,
- },
- {
- id: 6,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 1,
- },
- {
- id: 7,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 2,
- },
- {
- id: 8,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 3,
- },
- {
- id: 9,
- price: '82,03',
- amount: '0,15',
- total: '237,31',
- currency: 'TRY',
- type: 3,
- },
- ];
+// variables
+const dataArray: IPriceList[] = [
+ {
+ id: 1,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 1,
+ },
+ {
+ id: 2,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 1,
+ },
+ {
+ id: 3,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 3,
+ },
+ {
+ id: 4,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 3,
+ },
+ {
+ id: 5,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 2,
+ },
+ {
+ id: 6,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 1,
+ },
+ {
+ id: 7,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 2,
+ },
+ {
+ id: 8,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 3,
+ },
+ {
+ id: 9,
+ price: '82,03',
+ amount: '0,15',
+ total: '237,31',
+ currency: 'TRY',
+ type: 3,
+ },
+];
+const BuyOrders = () => {
+ const [data, setData] = React.useState([]);
+ const [menuOpened, setMenuOpened] = React.useState(false);
+
+ React.useEffect(() => {
setData(dataArray);
}, []);
- const handleMenuOpen = () => {
+ /**
+ * Toggles the state of the menu to open or close.
+ */
+ const handleMenuOpen = (): void => {
setMenuOpened(!menuOpened);
};
@@ -137,7 +152,7 @@ const BuyOrders = memo(() => {
- {data.map((item) => (
+ {data.map((item: IPriceList) => (
))}
@@ -147,6 +162,6 @@ const BuyOrders = memo(() => {
);
-});
+};
export default BuyOrders;
diff --git a/src/components/Widgets/BuyOrders/BuyOrdersRow.js b/src/components/Widgets/BuyOrders/BuyOrdersRow.tsx
similarity index 58%
rename from src/components/Widgets/BuyOrders/BuyOrdersRow.js
rename to src/components/Widgets/BuyOrders/BuyOrdersRow.tsx
index dfa54b3..7c63287 100644
--- a/src/components/Widgets/BuyOrders/BuyOrdersRow.js
+++ b/src/components/Widgets/BuyOrders/BuyOrdersRow.tsx
@@ -1,15 +1,20 @@
-import { memo, useState, useEffect } from 'react';
-import PropTypes from 'prop-types';
+import React from 'react';
-const BuyOrdersRow = memo(({ item }) => {
- const [color, setColor] = useState('white');
+// interfaces
+interface IProps {
+ item: any;
+}
- useEffect(() => {
+const BuyOrdersRow = ({ item }: IProps): React.JSX.Element => {
+ const [color, setColor] = React.useState