* Add useDeviceList hook Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add isCrossVerified func to matrixUtil Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add className prop in sidebar avatar comp Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add unverified session indicator in sidebar Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add info card component Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add css variables Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add cross signin status hook Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add hasCrossSigninAccountData function Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add cross signin info card in device manage component Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add cross signing and key backup component Signed-off-by: Ajay Bura <ajbura@gmail.com> * Fix typo Signed-off-by: Ajay Bura <ajbura@gmail.com> * WIP Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add cross singing dialogs Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add cross signing set/reset Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add SecretStorageAccess component Signed-off-by: Ajay Bura <ajbura@gmail.com> * Add key backup Signed-off-by: Ajay Bura <ajbura@gmail.com> * WIP * WIP * WIP * WIP * Show progress when restoring key backup * Add SSSS and key backup
33 lines
829 B
JavaScript
33 lines
829 B
JavaScript
/* eslint-disable import/prefer-default-export */
|
|
import { useState, useEffect } from 'react';
|
|
|
|
import initMatrix from '../../client/initMatrix';
|
|
|
|
export function useDeviceList() {
|
|
const mx = initMatrix.matrixClient;
|
|
const [deviceList, setDeviceList] = useState(null);
|
|
|
|
useEffect(() => {
|
|
let isMounted = true;
|
|
|
|
const updateDevices = () => mx.getDevices().then((data) => {
|
|
if (!isMounted) return;
|
|
setDeviceList(data.devices || []);
|
|
});
|
|
updateDevices();
|
|
|
|
const handleDevicesUpdate = (users) => {
|
|
if (users.includes(mx.getUserId())) {
|
|
updateDevices();
|
|
}
|
|
};
|
|
|
|
mx.on('crypto.devicesUpdated', handleDevicesUpdate);
|
|
return () => {
|
|
mx.removeListener('crypto.devicesUpdated', handleDevicesUpdate);
|
|
isMounted = false;
|
|
};
|
|
}, []);
|
|
return deviceList;
|
|
}
|