* Refine `SettingsSection` & `SettingsTab` * Add encryption tab * Add recovery section * Add device verification * Rename `Panel` into `State` * Update & add tests to user settings common * Add tests to `RecoveryPanel` * Add tests to `ChangeRecoveryKey` * Update CreateSecretStorageDialog-test snapshot * Add tests to `EncryptionUserSettingsTab` * Update existing screenshots of e2e tests * Add new encryption tab ownership to `@element-hq/element-crypto-web-reviewers` * Add e2e tests * Fix monospace font and add figma link to hardcoded value * Add unit to Icon * Improve e2e doc * Assert that the crypto module is defined * Add classname doc * Fix typo * Use `good` state instead of default * Rename `ChangeRecoveryKey.isSetupFlow` into `ChangeRecoveryKey.userHasKeyBackup` * Move `deleteCachedSecrets` fixture in `recovery.spec.ts` * Use one callback instead of two in `RecoveryPanel` * Fix docs and naming of `utils.createBot` * Fix typo in `RecoveryPanel` * Add more doc to the state of the `EncryptionUserSettingsTab` * Rename `verification_required` into `set_up_encryption` * Update test * ADd new license * Update comments and doc * Assert that `recoveryKey.encodedPrivateKey` is always defined * Add comments to explain how the secrets could be uncached * Use `matrixClient.secretStorage.getDefaultKeyId` instead of `matrixClient.getCrypto().checkKeyBackupAndEnable` to know if we need to set up a recovery key * Update existing screenshot to add encryption tab. * Update tests * Use new labels when changing the recovery key * Fix docs * Don't reset key backup when creating a recovery key * Fix doc
80 lines
2.1 KiB
Plaintext
80 lines
2.1 KiB
Plaintext
/*
|
|
* Copyright 2024 New Vector Ltd.
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
* Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
.mx_ChangeRecoveryKey {
|
|
.mx_InformationPanel_description {
|
|
text-align: center;
|
|
}
|
|
|
|
.mx_ChangeRecoveryKey_Form {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--cpd-space-8x);
|
|
|
|
.mx_ChangeRecoveryKey_footer {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--cpd-space-4x);
|
|
justify-content: center;
|
|
}
|
|
}
|
|
|
|
.mx_KeyPanel {
|
|
display: grid;
|
|
grid-template:
|
|
"header button" auto
|
|
"content button" auto / 1fr;
|
|
|
|
column-gap: var(--cpd-space-3x);
|
|
row-gap: var(--cpd-space-1x);
|
|
align-items: center;
|
|
|
|
> span {
|
|
grid-area: header;
|
|
}
|
|
|
|
> div {
|
|
grid-area: content;
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--cpd-space-2x);
|
|
color: var(--cpd-color-text-secondary);
|
|
|
|
.mx_KeyPanel_key {
|
|
font-family: Inconsolata, monospace;
|
|
/*
|
|
* From figma https://www.figma.com/design/qTWRfItpO3RdCjnTKPu4mL/Settings?node-id=375-77471&t=t7lozYrSI1AVZZ3U-4
|
|
*/
|
|
height: 70px;
|
|
box-sizing: border-box;
|
|
border-radius: var(--cpd-space-2x);
|
|
padding: var(--cpd-space-3x) var(--cpd-space-4x);
|
|
background-color: var(--cpd-color-bg-subtle-secondary);
|
|
}
|
|
}
|
|
|
|
> button {
|
|
margin: 0 var(--cpd-space-1x);
|
|
grid-area: button;
|
|
color: var(--cpd-color-icon-secondary-alpha);
|
|
}
|
|
}
|
|
|
|
.mx_KeyForm {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--cpd-space-8x);
|
|
}
|
|
|
|
.mx_ChangeRecoveryKey_footer {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--cpd-space-4x);
|
|
justify-content: center;
|
|
}
|
|
}
|