* record device client inforamtion events on app start * matrix-client-information -> matrix_client_information * fix types * remove another unused export * add docs link * display device client information in device details * update snapshots * integration-ish test client information in metadata * tests * fix tests * export helper * DeviceClientInformation type * Device manager - select all devices (#9330) * add device selection that does nothing * multi select and sign out of sessions * test multiple selection * fix type after rebase * select all sessions * rename type * use ExtendedDevice type everywhere * rename clientName to appName for less collision with UA parser * fix bad find and replace * rename ExtendedDeviceInfo to ExtendedDeviceAppInfo * rename DeviceType comp to DeviceTypeIcon * update tests for new required property deviceType * add stubbed user agent parsing
87 lines
3.0 KiB
TypeScript
87 lines
3.0 KiB
TypeScript
/*
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
import { LocalNotificationSettings } from 'matrix-js-sdk/src/@types/local_notifications';
|
|
import React, { useState } from 'react';
|
|
|
|
import { _t } from '../../../../languageHandler';
|
|
import Spinner from '../../elements/Spinner';
|
|
import SettingsSubsection from '../shared/SettingsSubsection';
|
|
import DeviceDetails from './DeviceDetails';
|
|
import DeviceExpandDetailsButton from './DeviceExpandDetailsButton';
|
|
import DeviceTile from './DeviceTile';
|
|
import { DeviceVerificationStatusCard } from './DeviceVerificationStatusCard';
|
|
import { ExtendedDevice } from './types';
|
|
|
|
interface Props {
|
|
device?: ExtendedDevice;
|
|
isLoading: boolean;
|
|
isSigningOut: boolean;
|
|
localNotificationSettings?: LocalNotificationSettings | undefined;
|
|
setPushNotifications?: (deviceId: string, enabled: boolean) => Promise<void> | undefined;
|
|
onVerifyCurrentDevice: () => void;
|
|
onSignOutCurrentDevice: () => void;
|
|
saveDeviceName: (deviceName: string) => Promise<void>;
|
|
}
|
|
|
|
const CurrentDeviceSection: React.FC<Props> = ({
|
|
device,
|
|
isLoading,
|
|
isSigningOut,
|
|
localNotificationSettings,
|
|
setPushNotifications,
|
|
onVerifyCurrentDevice,
|
|
onSignOutCurrentDevice,
|
|
saveDeviceName,
|
|
}) => {
|
|
const [isExpanded, setIsExpanded] = useState(false);
|
|
|
|
return <SettingsSubsection
|
|
heading={_t('Current session')}
|
|
data-testid='current-session-section'
|
|
>
|
|
{ /* only show big spinner on first load */ }
|
|
{ isLoading && !device && <Spinner /> }
|
|
{ !!device && <>
|
|
<DeviceTile
|
|
device={device}
|
|
>
|
|
<DeviceExpandDetailsButton
|
|
data-testid='current-session-toggle-details'
|
|
isExpanded={isExpanded}
|
|
onClick={() => setIsExpanded(!isExpanded)}
|
|
/>
|
|
</DeviceTile>
|
|
{ isExpanded &&
|
|
<DeviceDetails
|
|
device={device}
|
|
localNotificationSettings={localNotificationSettings}
|
|
setPushNotifications={setPushNotifications}
|
|
isSigningOut={isSigningOut}
|
|
onVerifyDevice={onVerifyCurrentDevice}
|
|
onSignOutDevice={onSignOutCurrentDevice}
|
|
saveDeviceName={saveDeviceName}
|
|
/>
|
|
}
|
|
<br />
|
|
<DeviceVerificationStatusCard device={device} onVerifyDevice={onVerifyCurrentDevice} />
|
|
</>
|
|
}
|
|
</SettingsSubsection>;
|
|
};
|
|
|
|
export default CurrentDeviceSection;
|