Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
E
ESYTD
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Дияр Амангельды
ESYTD
Commits
b7dd0273
Commit
b7dd0273
authored
Jul 31, 2024
by
Merekeyev Dias
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactor styling
parent
24fa6480
Changes
18
Show whitespace changes
Inline
Side-by-side
Showing
18 changed files
with
171 additions
and
90 deletions
+171
-90
index.html
index.html
+1
-5
src/App.css
src/App.css
+26
-0
src/components/Header/Header.module.css
src/components/Header/Header.module.css
+9
-8
src/components/Header/Header.tsx
src/components/Header/Header.tsx
+14
-12
src/index.css
src/index.css
+0
-1
src/main.tsx
src/main.tsx
+5
-3
src/pages/HomePage/Columns.tsx
src/pages/HomePage/Columns.tsx
+7
-6
src/pages/HomePage/HomePage.tsx
src/pages/HomePage/HomePage.tsx
+26
-28
src/pages/HomePage/Homepage.module.css
src/pages/HomePage/Homepage.module.css
+15
-0
src/pages/HomePage/utils.ts
src/pages/HomePage/utils.ts
+1
-1
src/pages/ManageOrganization/ManageOrganization.tsx
src/pages/ManageOrganization/ManageOrganization.tsx
+1
-1
src/pages/RequestPage/Columns.tsx
src/pages/RequestPage/Columns.tsx
+35
-16
src/pages/RequestPage/RequestPage.module.css
src/pages/RequestPage/RequestPage.module.css
+21
-0
src/pages/RequestPage/RequestPage.tsx
src/pages/RequestPage/RequestPage.tsx
+7
-6
src/store/slices/mainPaginationSlice.ts
src/store/slices/mainPaginationSlice.ts
+0
-0
src/store/slices/reqPaginationSlice.ts
src/store/slices/reqPaginationSlice.ts
+0
-0
src/store/slices/syncBtnSlice.ts
src/store/slices/syncBtnSlice.ts
+0
-0
src/store/store.ts
src/store/store.ts
+3
-3
No files found.
index.html
View file @
b7dd0273
...
...
@@ -5,10 +5,6 @@
<link
rel=
"icon"
type=
"image/svg+xml"
href=
"/vite.svg"
/>
<meta
name=
"viewport"
content=
"width=device-width, initial-scale=1.0"
/>
<title>
ЕСУТД
</title>
<link
rel=
"preconnect"
href=
"https://fonts.googleapis.com"
>
<link
rel=
"preconnect"
href=
"https://fonts.gstatic.com"
crossorigin
>
<link
href=
"https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap"
rel=
"stylesheet"
>
</head>
<body>
<div
id=
"root"
></div>
...
...
src/App.css
View file @
b7dd0273
:root
{
--main-blue
:
#041225
;
--icon-blue
:
#0E2B52
;
}
.container
{
width
:
100%
;
max-width
:
1500px
;
margin
:
0
auto
;
}
.text-blue
{
color
:
var
(
--icon-blue
);
}
.text-1
{
font-size
:
1rem
!important
;
}
.text-125
{
font-size
:
1.25rem
!important
;
}
.text-15
{
font-size
:
1.5rem
!important
;
}
\ No newline at end of file
src/components/Header/Header.css
→
src/components/Header/Header.
module.
css
View file @
b7dd0273
.header
{
background-color
:
#041225
;
background-color
:
var
(
--main-blue
)
;
color
:
#fff
;
display
:
flex
;
padding
:
1rem
.5rem
;
...
...
@@ -9,6 +9,7 @@
.header_left
{
display
:
flex
;
align-items
:
center
;
gap
:
.5rem
;
}
.header_title
{
...
...
@@ -25,30 +26,30 @@
}
/* Customizing drawer */
.custom
-
drawer
{
.custom
_
drawer
{
color
:
#fff
;
background-color
:
#041225
!important
;
background-color
:
var
(
--main-blue
)
!important
;
}
.custom
-drawer
.ant-drawer-header
{
.custom
_drawer
:global
(
.ant-drawer-header
)
{
padding-bottom
:
1.35rem
;
border-bottom
:
2px
solid
;
}
.custom
-drawer
.ant-drawer-header-title
{
.custom
_drawer
:global
(
.ant-drawer-header-title
)
{
flex-direction
:
row-reverse
;
}
.custom
-drawer
.ant-drawer-title
{
.custom
_drawer
:global
(
.ant-drawer-title
)
{
font-size
:
1.1rem
;
letter-spacing
:
1px
;
}
.custom
-drawer
.ant-drawer-close
span
{
.custom
_drawer
:global
(
.ant-drawer-close
span
)
{
color
:
#fff
;
}
.custom
-drawer
.ant-drawer-body
{
.custom
_drawer
:global
(
.ant-drawer-body
)
{
margin-top
:
1.2rem
;
padding
:
0
;
}
\ No newline at end of file
src/components/Header/Header.tsx
View file @
b7dd0273
...
...
@@ -5,7 +5,7 @@ import { Menu, Button, Drawer } from 'antd';
import
type
{
MenuProps
}
from
'
antd
'
;
import
{
clearToken
}
from
'
@/store/store
'
;
import
'
./Header
.css
'
;
import
styles
from
'
./Header.module
.css
'
;
type
MenuItem
=
Required
<
MenuProps
>
[
'
items
'
][
number
];
...
...
@@ -47,23 +47,22 @@ const Header: React.FC = () => {
};
return
(
<
header
className=
"header"
>
<
div
className=
"header_left"
>
<
header
className=
{
styles
.
header
}
>
<
div
className=
{
styles
.
header_left
}
>
<
Button
type=
'text'
onClick=
{
()
=>
{
setOpenMenu
(
true
);
}
}
>
<
span
className=
'material-icons'
style=
{
{
fontSize
:
24
,
color
:
'
#fff
'
}
}
>
menu
</
span
>
</
Button
>
icon=
{
<
span
className=
'material-icons'
style=
{
{
fontSize
:
24
,
color
:
'
#fff
'
}
}
>
menu
</
span
>
}
/>
<
Drawer
open=
{
openMenu
}
onClose=
{
()
=>
{
setOpenMenu
(
false
);
}
}
placement=
'left'
className=
'custom-drawer'
className=
{
styles
.
custom_drawer
}
title=
"ЕСУТД"
>
<
Menu
...
...
@@ -71,15 +70,18 @@ const Header: React.FC = () => {
items=
{
MenuItems
}
selectedKeys=
{
[
currentNav
]
}
mode=
'inline'
className=
"menu"
className=
{
styles
.
menu
}
onClick=
{
handleMenuClick
}
/>
</
Drawer
>
<
h1
className=
"header_title"
>
ЕСУТД
</
h1
>
<
h1
className=
{
styles
.
header_title
}
>
ЕСУТД
</
h1
>
</
div
>
<
Button
type=
'text'
className=
"header_logout"
onClick=
{
handleLogout
}
>
<
span
className=
'material-icons'
style=
{
{
fontSize
:
24
,
color
:
'
#fff
'
}
}
>
logout
</
span
>
</
Button
>
<
Button
type=
'text'
className=
{
styles
.
header_logout
}
onClick=
{
handleLogout
}
icon=
{
<
span
className=
'material-icons'
style=
{
{
fontSize
:
24
,
color
:
'
#fff
'
}
}
>
logout
</
span
>
}
/>
</
header
>
);
};
...
...
src/index.css
View file @
b7dd0273
...
...
@@ -6,7 +6,6 @@
html
,
body
{
box-sizing
:
border-box
;
font-family
:
Open
Sans
;
font-weight
:
700
;
}
...
...
src/main.tsx
View file @
b7dd0273
import
React
from
'
react
'
;
import
ReactDOM
from
'
react-dom/client
'
;
import
App
from
'
./App.tsx
'
;
import
{
Provider
}
from
'
react-redux
'
;
import
'
./index.css
'
;
import
App
from
'
./App.tsx
'
;
import
{
store
,
persistor
}
from
'
../src/store/store.ts
'
;
import
{
PersistGate
}
from
'
redux-persist/integration/react
'
;
import
'
../node_modules/material-icons/iconfont/material-icons.css
'
import
'
./index.css
'
;
export
type
RootState
=
ReturnType
<
typeof
store
.
getState
>
;
ReactDOM
.
createRoot
(
document
.
getElementById
(
'
root
'
)
!
).
render
(
...
...
src/pages/HomePage/Columns.tsx
View file @
b7dd0273
...
...
@@ -5,9 +5,10 @@ import { Button, Space, Tag, Modal, Checkbox, message } from 'antd';
import
type
{
TableProps
}
from
'
antd
'
;
import
{
useDeleteOrganizationMutation
}
from
'
@/api/organizationApi
'
;
import
{
addCheckedCode
,
removeCheckedCode
}
from
'
@/store/slices/syncBtn
'
;
import
{
setCurrentPage
}
from
'
@/store/slices/mainPagination
'
;
import
{
addCheckedCode
,
removeCheckedCode
}
from
'
@/store/slices/syncBtn
Slice
'
;
import
{
setCurrentPage
}
from
'
@/store/slices/mainPagination
Slice
'
;
import
{
getStatusText
,
getStatusColor
}
from
'
./utils
'
;
import
styles
from
'
./Homepage.module.css
'
;
export
interface
DataType
{
id
:
number
;
...
...
@@ -53,7 +54,7 @@ export const columns: TableProps<DataType>['columns'] = [
dataIndex
:
"
status
"
,
key
:
"
status
"
,
render
:
(
_
,
record
)
=>
(
<
Tag
color=
{
getStatusColor
(
record
.
status
)
}
style=
{
{
fontSize
:
'
14px
'
}
}
>
<
Tag
color=
{
getStatusColor
(
record
.
status
)
}
>
{
getStatusText
(
record
.
status
)
}
</
Tag
>
)
...
...
@@ -86,7 +87,7 @@ export const CheckboxColumn: React.FC<{ data: DataType }> = ({ data }) => {
return
(
<
Checkbox
className=
'checkbox_org--custom'
className=
{
styles
.
custom_checkbox
}
checked=
{
checked
}
onChange=
{
handleCheck
}
id=
{
`checkbox-${data.id}`
}
...
...
@@ -132,12 +133,12 @@ export const ActionColumn: React.FC<{ data: DataType }> = ({ data }) => {
<
Space
>
<
Button
onClick=
{
handleEditClick
}
icon=
{
<
span
className=
'material-icons
'
style=
{
{
fontSize
:
20
,
color
:
'
#0E2B52
'
}
}
>
visibility
</
span
>
}
icon=
{
<
span
className=
'material-icons
text-blue text-125'
>
visibility
</
span
>
}
type=
'text'
/>
<
Button
onClick=
{
showDeleteModal
}
icon=
{
<
span
className=
'material-icons
'
style=
{
{
fontSize
:
20
,
color
:
'
#0E2B52
'
}
}
>
delete
</
span
>
}
icon=
{
<
span
className=
'material-icons
text-blue text-125'
>
delete
</
span
>
}
type=
'text'
/>
<
Modal
...
...
src/pages/HomePage/HomePage.tsx
View file @
b7dd0273
...
...
@@ -6,10 +6,10 @@ import { TableRef } from 'antd/es/table';
import
{
useGetOrganizationsQuery
}
from
'
@/api/organizationApi
'
;
import
{
useUpdateDictionaryMutation
}
from
'
@/api/manualApi
'
;
import
{
setCurrentPage
,
setTotalOrgNumber
}
from
'
@/store/slices/mainPagination
'
;
import
{
setDisabled
,
clearCheckedCodes
}
from
'
@/store/slices/syncBtn
'
;
import
{
setCurrentPage
,
setTotalOrgNumber
}
from
'
@/store/slices/mainPagination
Slice
'
;
import
{
setDisabled
,
clearCheckedCodes
}
from
'
@/store/slices/syncBtn
Slice
'
;
import
{
DataType
,
columns
}
from
'
./Columns
'
;
import
'
./Homepag
e.css
'
;
import
styles
from
'
./Homepage.modul
e.css
'
;
const
HomePage
:
React
.
FC
=
()
=>
{
const
navigate
=
useNavigate
();
...
...
@@ -72,7 +72,7 @@ const HomePage: React.FC = () => {
scroll=
{
{
scrollToFirstRowOnChange
:
true
,
x
:
'
max-content
'
,
y
:
47
0
y
:
window
.
innerHeight
-
25
0
}
}
pagination=
{
{
position
:
[
'
bottomCenter
'
],
...
...
@@ -107,22 +107,21 @@ const HomePage: React.FC = () => {
},
[
checkedCodes
,
dispatch
])
return
(
<
div
className=
"container"
>
<
section
className=
'section'
>
<
Space
size=
{
'
middle
'
}
>
<
div
className=
'container'
>
<
Space
className=
{
styles
.
btn_section
}
size=
{
'
middle
'
}
>
<
Button
className=
'add_title'
className=
{
styles
.
btn
}
onClick=
{
handleAddClick
}
icon=
{
<
span
className=
'material-icons'
style=
{
{
fontSize
:
20
,
color
:
'
#0E2B52
'
}
}
>
add_circle
</
span
>
}
icon=
{
<
span
className=
'material-icons text-blue text-15'
>
add_circle
</
span
>
}
>
Добавить
</
Button
>
<
Button
className=
'add_title'
className=
{
styles
.
btn
}
onClick=
{
handleSyncClick
}
disabled=
{
syncBtnState
}
loading=
{
isSyncLoading
}
icon=
{
<
span
className=
'material-icons'
style=
{
{
fontSize
:
22
,
color
:
'
#0E2B52
'
}
}
>
sync
</
span
>
}
icon=
{
<
span
className=
'material-icons text-blue text-15'
>
sync
</
span
>
}
>
Синхронизировать справочники
</
Button
>
...
...
@@ -130,7 +129,6 @@ const HomePage: React.FC = () => {
<
div
className=
"data"
>
{
table
}
</
div
>
</
section
>
</
div
>
);
}
...
...
src/pages/HomePage/Homepage.css
→
src/pages/HomePage/Homepage.
module.
css
View file @
b7dd0273
.add_title
{
font-size
:
12px
;
line-height
:
18px
;
text-decoration
:
none
;
.btn_section
{
margin
:
1rem
0
;
}
.btn
{
font-size
:
.8rem
;
font-weight
:
700
;
margin-left
:
-10px
;
text-decoration
:
none
;
margin-left
:
.5rem
;
}
/* Custom antd checkbox */
.c
heckbox_org--custom
.ant-checkbox-inner
{
.c
ustom_checkbox
:global
(
.ant-checkbox-inner
)
{
border-color
:
#33333386
;
}
\ No newline at end of file
src/pages/HomePage/utils.ts
View file @
b7dd0273
src/pages/ManageOrganization/ManageOrganization.tsx
View file @
b7dd0273
...
...
@@ -4,7 +4,7 @@ import { useSelector, useDispatch } from 'react-redux';
import
{
Form
,
Input
,
Button
,
Select
,
message
}
from
'
antd
'
;
import
{
useEditOrganizationMutation
,
useGetOrganizationQuery
,
useGetOrganizationsQuery
}
from
'
@/api/organizationApi
'
;
import
{
setTotalOrgNumber
,
setCurrentPage
}
from
'
@/store/slices/mainPagination
'
;
import
{
setTotalOrgNumber
,
setCurrentPage
}
from
'
@/store/slices/mainPagination
Slice
'
;
import
'
./ManageOrganization.css
'
;
interface
OrganizationValues
{
...
...
src/pages/RequestPage/Columns.tsx
View file @
b7dd0273
...
...
@@ -4,6 +4,7 @@ import type { TableProps } from 'antd';
import
dayjs
from
'
dayjs
'
;
import
{
getStatusText
,
getStatusColor
,
openXMLInNewPage
,
downloadXML
}
from
'
./utils
'
;
import
styles
from
'
./RequestPage.module.css
'
;
export
interface
DataType
{
id
:
number
;
...
...
@@ -31,22 +32,33 @@ export const columns: TableProps<DataType>['columns'] = [
key
:
"
xml
"
,
width
:
'
1%
'
,
render
:
(
_
,
record
)
=>
(
<
div
style=
{
{
display
:
'
flex
'
,
alignItems
:
'
center
'
,
gap
:
5
}
}
>
<
div
className=
{
styles
.
data_interchange_btnGroup
}
>
<
Button
className=
{
styles
.
data_interchange_btn
}
type=
'link'
onClick=
{
()
=>
openXMLInNewPage
(
record
.
xml
)
}
>
Открыть
</
Button
>
<
Button
className=
{
styles
.
data_interchange_btn
}
type=
'link'
onClick=
{
()
=>
downloadXML
(
record
.
xml
,
record
.
id
)
}
style=
{
{
padding
:
0
}
}
icon=
{
<
span
className=
'material-icons'
>
download
</
span
>
}
icon=
{
<
span
className=
'material-icons text-125'
>
download
</
span
>
}
/>
<
Button
type=
'link'
onClick=
{
()
=>
openXMLInNewPage
(
record
.
xml
)
}
style=
{
{
padding
:
0
}
}
>
Открыть XML
</
Button
>
</
div
>
),
},
{
title
:
"
JSON
"
,
key
:
"
json
"
,
width
:
'
5%
'
,
},
{
title
:
"
Дата отправки
"
,
dataIndex
:
"
sendDate
"
,
key
:
"
sendDate
"
,
width
:
'
6
%
'
,
width
:
'
7
%
'
,
render
:
(
_
,
record
)
=>
(
<
span
>
{
dayjs
(
record
.
sendDate
).
format
(
'
DD-MM-YYYY HH:mm:ss
'
)
}
</
span
>
)
...
...
@@ -69,7 +81,7 @@ export const columns: TableProps<DataType>['columns'] = [
key
:
"
status
"
,
width
:
'
1%
'
,
render
:
(
_
,
record
)
=>
(
<
Tag
color=
{
getStatusColor
(
record
.
status
)
}
style=
{
{
fontSize
:
'
12px
'
}
}
>
<
Tag
color=
{
getStatusColor
(
record
.
status
)
}
>
{
getStatusText
(
record
.
status
)
}
</
Tag
>
)
...
...
@@ -80,14 +92,20 @@ export const columns: TableProps<DataType>['columns'] = [
key
:
"
errorMessage
"
,
width
:
'
1%
'
,
render
:
(
_
,
record
)
=>
(
<
Button
type=
'link'
onClick=
{
()
=>
openXMLInNewPage
(
record
.
xml
)
}
style=
{
{
padding
:
0
}
}
>
Открыть сообщение
</
Button
>
<
Button
className=
{
styles
.
data_interchange_btn
}
type=
'link'
onClick=
{
()
=>
openXMLInNewPage
(
record
.
xml
)
}
>
Открыть сообщение
</
Button
>
)
},
{
title
:
"
Дата переотправки
"
,
dataIndex
:
"
resendDate
"
,
key
:
"
resendDate
"
,
width
:
'
6%
'
width
:
'
6%
'
,
},
{
title
:
"
Количество попыток
"
,
...
...
@@ -97,6 +115,7 @@ export const columns: TableProps<DataType>['columns'] = [
},
{
width
:
'
1%
'
,
align
:
'
center
'
,
render
:
(
_
,
record
)
=>
{
return
(
<
ResendColumn
...
...
@@ -129,10 +148,10 @@ export const ResendColumn: React.FC<{ data: DataType }> = ({ data }) => {
};
return
(
<
div
style=
{
{
textAlign
:
'
center
'
}
}
>
<>
<
Button
onClick=
{
showResendModal
}
icon=
{
<
span
className=
'material-icons
'
style=
{
{
fontSize
:
20
,
color
:
'
#0E2B52
'
}
}
>
mail
</
span
>
}
icon=
{
<
span
className=
'material-icons
text-blue text-125'
>
mail
</
span
>
}
type=
'text'
/>
<
Modal
...
...
@@ -143,6 +162,6 @@ export const ResendColumn: React.FC<{ data: DataType }> = ({ data }) => {
>
<
p
>
Подтвердите переотправку запроса.
</
p
>
</
Modal
>
</
div
>
</>
)
}
\ No newline at end of file
src/pages/RequestPage/RequestPage.css
→
src/pages/RequestPage/RequestPage.
module.
css
View file @
b7dd0273
.filter
{
margin
:
1rem
1rem
1rem
;
.filter
_section
{
margin
:
1rem
;
display
:
flex
;
justify-content
:
space-between
;
align-items
:
center
;
...
...
@@ -9,3 +9,13 @@
display
:
flex
;
gap
:
1rem
;
}
.data_interchange_btnGroup
{
display
:
flex
;
align-items
:
center
;
gap
:
5px
;
}
.data_interchange_btn
{
padding
:
0
;
}
\ No newline at end of file
src/pages/RequestPage/RequestPage.tsx
View file @
b7dd0273
...
...
@@ -7,9 +7,9 @@ import { DatePicker, Select, Button, Table } from 'antd';
import
{
TableRef
}
from
'
antd/es/table
'
;
import
{
useGetRequestsQuery
}
from
'
@/api/requestApi
'
;
import
{
setCurrentPage
,
setTotalReqNumber
}
from
'
@/store/slices/reqPagination
'
import
{
setCurrentPage
,
setTotalReqNumber
}
from
'
@/store/slices/reqPagination
Slice
'
import
{
columns
,
DataType
}
from
'
./Columns
'
;
import
'
./RequestPag
e.css
'
;
import
styles
from
'
./RequestPage.modul
e.css
'
;
const
DATE_FORMAT
=
'
YYYY-MM-DD
'
;
const
DEFAULT_DATES
=
{
...
...
@@ -88,9 +88,9 @@ const RequestPage: React.FC = () => {
let
max
:
number
=
-
Infinity
;
if
(
isSuccess
)
{
console
.
log
(
window
.
innerHeight
)
reqs
.
list
.
forEach
((
req
)
=>
{
const
dateValue
=
new
Date
(
req
.
sendDate
).
valueOf
();
console
.
log
(
dateValue
);
if
(
min
>
dateValue
&&
dateValue
!=
0
)
{
min
=
dateValue
;
}
...
...
@@ -107,7 +107,7 @@ const RequestPage: React.FC = () => {
scroll=
{
{
scrollToFirstRowOnChange
:
true
,
x
:
'
max-content
'
,
y
:
40
0
y
:
window
.
innerHeight
-
27
0
}
}
pagination=
{
{
position
:
[
'
bottomCenter
'
],
...
...
@@ -136,10 +136,11 @@ const RequestPage: React.FC = () => {
return
(
<
div
className=
"container"
>
<
div
className=
"filter"
>
<
div
className=
"fields"
>
<
div
className=
{
styles
.
filter_section
}
>
<
div
className=
{
styles
.
fields
}
>
<
div
className=
"dates"
>
<
DatePicker
.
RangePicker
id=
{
{
start
:
'
startDate
'
,
end
:
'
endDate
'
}
}
onChange=
{
onRangeChange
}
defaultValue=
{
[
dayjs
(
DEFAULT_DATES
.
startDate
,
DATE_FORMAT
),
...
...
src/store/slices/mainPagination.ts
→
src/store/slices/mainPagination
Slice
.ts
View file @
b7dd0273
File moved
src/store/slices/reqPagination.ts
→
src/store/slices/reqPagination
Slice
.ts
View file @
b7dd0273
File moved
src/store/slices/syncBtn.ts
→
src/store/slices/syncBtn
Slice
.ts
View file @
b7dd0273
File moved
src/store/store.ts
View file @
b7dd0273
...
...
@@ -3,9 +3,9 @@ import storage from 'redux-persist/lib/storage';
import
{
persistReducer
,
persistStore
}
from
'
redux-persist
'
;
import
{
apiSlice
}
from
'
../api/mainApi
'
;
import
mainPaginationReducer
from
'
./slices/mainPagination
'
;
import
reqPaginationReducer
from
'
./slices/reqPagination
'
;
import
syncBtnReducer
from
'
./slices/syncBtn
'
;
import
mainPaginationReducer
from
'
./slices/mainPagination
Slice
'
;
import
reqPaginationReducer
from
'
./slices/reqPagination
Slice
'
;
import
syncBtnReducer
from
'
./slices/syncBtn
Slice
'
;
interface
AuthState
{
token
:
string
|
null
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment