Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
import React, { useCallback, useContext, useEffect, useState } from 'react'
import { IPartnersInfo } from '../../models/partnersInfo.model'
import 'react-draft-wysiwyg/dist/react-draft-wysiwyg.css'
import './partnersInfo.scss'
import { PartnersInfoService } from '../../services/partnersInfo.service'
import { UserContext, UserContextProps } from '../../hooks/userContext'
import Loader from '../Loader/Loader'
import { CheckboxType } from '../../enum/checkboxType.enum'
const PartnersInfo: React.FC = () => {
const [refreshData, setRefreshData] = useState(false)
const [isLoading, setIsLoading] = useState<boolean>(false)
const [partnersInfo, setPartnersInfo] = useState<IPartnersInfo>({
grdf_failure: false,
enedis_failure: false,
egl_failure: false,
notification_activated: false,
})
const { user }: Partial<UserContextProps> = useContext(UserContext)
const handleCheckboxChange = (value: boolean, type: CheckboxType): void => {
switch (type) {
case CheckboxType.GRDF:
setPartnersInfo((prevPartnersInfo) => ({
...prevPartnersInfo,
grdf_failure: value,
}))
break
case CheckboxType.ENEDIS:
setPartnersInfo((prevPartnersInfo) => ({
...prevPartnersInfo,
enedis_failure: value,
}))
break
case CheckboxType.EGL:
setPartnersInfo((prevPartnersInfo) => ({
...prevPartnersInfo,
egl_failure: value,
}))
break
case CheckboxType.NOTIFICATION:
setPartnersInfo((prevPartnersInfo) => ({
...prevPartnersInfo,
notification_activated: value,
}))
break
default:
throw new Error('Unknown checkbox type')
}
}
const handleCancel = useCallback(() => {
setRefreshData(true)
}, [setRefreshData])
const resetFields = useCallback(() => {
setPartnersInfo({
grdf_failure: false,
enedis_failure: false,
egl_failure: false,
notification_activated: false,
})
}, [setPartnersInfo])
useEffect(() => {
let subscribed = true
resetFields()
setIsLoading(true)
async function getPartnersInfo() {
if (user) {
const partnersInfoService = new PartnersInfoService()
const partnersInfoResp: IPartnersInfo | null =
await partnersInfoService.getPartnersInfo()
if (partnersInfoResp) {
setPartnersInfo({
grdf_failure: partnersInfoResp.grdf_failure,
enedis_failure: partnersInfoResp.enedis_failure,
egl_failure: partnersInfoResp.egl_failure,
notification_activated: partnersInfoResp.notification_activated,
})
}
}
setIsLoading(false)
}
if (subscribed) {
getPartnersInfo()
}
return () => {
subscribed = false
setRefreshData(false)
}
}, [user, refreshData, setPartnersInfo, resetFields])
const handleSave = async (): Promise<void> => {
if (user) {
const partnersInfoService = new PartnersInfoService()
await partnersInfoService.savePartnersInfo(partnersInfo, user.xsrftoken)
}
}
return (
<>
{isLoading ? (
<Loader />
) : (
<div className="partnersInfo">
<h2>État des services des partenaires</h2>
<div>
<p className="title">Affichage de la pop-up dans Ecolyo</p>
<div className="switch_div">
Pop-up active
<input
type="checkbox"
id="switch_notification"
onChange={(event) => {
handleCheckboxChange(
event.currentTarget.checked,
CheckboxType.NOTIFICATION
)
}}
checked={partnersInfo.notification_activated}
/>
<label htmlFor="switch_notification"></label>
</div>
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
<p className="title">Services concernés</p>
<div className="switch_div">
Panne Enedis
<input
type="checkbox"
id="switch_enedis"
onChange={(event) => {
handleCheckboxChange(
event.currentTarget.checked,
CheckboxType.ENEDIS
)
}}
checked={partnersInfo.enedis_failure}
/>
<label htmlFor="switch_enedis"></label>
</div>
<div className="switch_div">
Panne EGL
<input
type="checkbox"
id="switch_egl"
onChange={(event) => {
handleCheckboxChange(
event.currentTarget.checked,
CheckboxType.EGL
)
}}
checked={partnersInfo.egl_failure}
/>
<label htmlFor="switch_egl"></label>
</div>
<div className="switch_div">
Panne GRDF
<input
type="checkbox"
id="switch_grdf"
onChange={(event) => {
handleCheckboxChange(
event.currentTarget.checked,
CheckboxType.GRDF
)
}}
checked={partnersInfo.grdf_failure}
/>
<label htmlFor="switch_grdf"></label>
</div>
<div className="buttons">
<button className="btnCancel" onClick={handleCancel}>
Annuler
</button>
<button className="btnValid" onClick={handleSave}>
Sauvegarder
</button>
</div>
</div>
</div>
)}
</>
)
}
export default PartnersInfo