diff --git a/src/pages/Setting/ConditionalRender.tsx b/src/pages/Setting/ConditionalRender.tsx new file mode 100644 index 0000000..8ed1537 --- /dev/null +++ b/src/pages/Setting/ConditionalRender.tsx @@ -0,0 +1,46 @@ +import axios from "axios"; +import React, { useEffect, useState } from "react"; + +type ConditionalRenderProps = { + isLoading: boolean; + childrenUser?: JSX.Element; + childrenAdmin?: JSX.Element; + childrenManager?: JSX.Element; +}; + +const ConditionalRender = ({ + isLoading, + childrenUser, + childrenAdmin, + childrenManager, +}: ConditionalRenderProps): JSX.Element => { + const [role, setRole] = useState(""); + + useEffect(() => { + const axiosAccount = async () => { + try { + const { data } = await axios.get("https://admin.pena.digital/user/643e23f3dba63ba17272664d"); + setRole(data.role); + } catch (error) { + console.error("Ошибка при получение роли пользавателя"); + } + }; + axiosAccount(); + }, [role]); + + if (isLoading) { + if (role === "admin") { + return childrenAdmin ? childrenAdmin :
Администратор
; + } + if (role === "user") { + return childrenUser ? childrenUser :
Пользователь
; + } + if (role === "manager") { + return childrenManager ? childrenManager :
Менеджер
; + } + } + + return ; +}; + +export default ConditionalRender;