Compare commits

..

2 Commits

Author SHA1 Message Date
Mikola
2a5991da1f error boundary and table pagination 2024-03-19 16:39:36 +03:00
Mikola
6afccb19d8 error boundary and table pagination 2024-03-19 16:39:00 +03:00
7 changed files with 96 additions and 8 deletions

View File

@ -1,5 +1,7 @@
import React, { Component } from "react";
import { Fallback } from "./Fallback";
class ErrorBoundary extends Component {
state = {
error: null
@ -13,7 +15,7 @@ class ErrorBoundary extends Component {
const { error } = this.state;
if (error) {
return <div>Что-то пошло не так =( {error}</div>;
return <Fallback />;
}
return this.props.children;
}

19
src/hoc/Fallback.jsx Normal file
View File

@ -0,0 +1,19 @@
import React from "react";
import rightArrow from "assets/icons/arrows/arrowRight.svg";
import logo from "assets/images/logo/ITguild.svg";
import "./fallback.scss";
export const Fallback = () => {
return (
<div className="fallback">
<img src={logo} alt="logo" className="logo" />
<h1>Произошла непредвиденная ошибка</h1>
<a href="/profile">
Вернуться назад
<img src={rightArrow} alt="arrow" />
</a>
</div>
);
};

19
src/hoc/fallback.scss Normal file
View File

@ -0,0 +1,19 @@
.fallback {
display: flex;
flex-direction: column;
align-items: center;
padding: 100px;
gap: 15px;
img {
max-width: 250px;
}
a {
display: flex;
column-gap: 10px;
align-items: center;
font-size: 16px;
color: black;
}
}

View File

@ -3,11 +3,14 @@ import ReactDOM from "react-dom/client";
import { Provider } from "react-redux";
import App from "./App";
import ErrorBoundary from "./hoc/ErrorBoundary";
import "./index.css";
import { store } from "./store/store";
ReactDOM.createRoot(document.getElementById("root")).render(
<ErrorBoundary>
<Provider store={store}>
<App />
</Provider>
</ErrorBoundary>
);

View File

@ -1,5 +1,6 @@
import { getTheme } from "@table-library/react-table-library/baseline";
import { CompactTable } from "@table-library/react-table-library/compact";
import { usePagination } from "@table-library/react-table-library/pagination";
import { useSort } from "@table-library/react-table-library/sort";
import { useTheme } from "@table-library/react-table-library/theme";
import React, { useEffect, useState } from "react";
@ -101,6 +102,13 @@ export const PartnerCategories = () => {
}
);
const pagination = usePagination(data, {
state: {
page: 0,
size: 5
}
});
useEffect(() => {
setLoader(true);
apiRequest("/project/my-employee").then((el) => {
@ -259,7 +267,30 @@ export const PartnerCategories = () => {
data={data}
theme={theme}
sort={sort}
pagination={pagination}
/>
<div className="table__pagination">
<span>
Total Pages: {pagination.state.getTotalPages(data.nodes)}
</span>
<span className="table__pages">
Page:{" "}
{pagination.state.getPages(data.nodes).map((_, index) => (
<button
key={index}
type="button"
style={{
fontWeight:
pagination.state.page === index ? "bold" : "normal"
}}
onClick={() => pagination.fns.onSetPage(index)}
>
{index + 1}
</button>
))}
</span>
</div>
</>
) : (
<div className="partner-categories__empty">

View File

@ -176,5 +176,19 @@
font-size: 16px;
align-items: center;
}
&__pagination {
width: 100%;
display: flex;
justify-content: space-between;
font-size: 16px;
align-items: center;
}
&__pages {
display: flex;
column-gap: 5px;
align-items: center;
}
}
}