mirror of
https://github.com/bitwarden/browser
synced 2025-12-13 06:43:35 +00:00
* [PM-2135] feat: create new user-verification module
* [PM-2136] feat: add ability to remove form field bottom margin
(cherry picked from commit 05925ff77ed47f3865c2aecade8271390d9e2fa6)
* [PM-2135] feat: refactor user-verification component
* [PM-2135] feat: refactor user-verification-prompt
* [PM-2135] feat: use form validation in prompt
* [PM-2135] feat: change autofocus target
* [PM-2135] chore: clean up old code
* [PM-2135] feat: allow user verification to show invalid password error
* [PM-2135] feat: hack mark as touched to get error to display
* [PM-2135] chore: move to auth
* [PM-2135] fix: hardcoded dialog buttons
* [PM-2135] feat: add onDestroy handler
* [PM-2135] fix: remove unecessary directive input
* [PM-2135] feat: add password toggle
* [PM-2135] chore: add hack comment
* [PM-2135] chore: move services to auth folder and rename
* [PM-2135] fix: show correct error messages
* [PM-2135] fix: re-add non-existant files to whitelist
I honestly don't know why the linter is complaining about this
* Fix capital letters whitelist
* [PM-2135] chore: remove rows that were mistakenly added during merge from master
* [PM-2135] chore: remove rows that were mistakenly added during merge from master
* [PM-2135] feat: disable built-in browser validations
* Revert "[PM-2135] feat: disable built-in browser validations"
This reverts commit 969f75822a.
---------
Co-authored-by: Thomas Rittson <trittson@bitwarden.com>
82 lines
3.1 KiB
TypeScript
82 lines
3.1 KiB
TypeScript
import * as os from "os";
|
|
|
|
import { Component, OnInit } from "@angular/core";
|
|
import { UntypedFormBuilder } from "@angular/forms";
|
|
|
|
import { DialogServiceAbstraction, SimpleDialogType } from "@bitwarden/angular/services/dialog";
|
|
import { ExportComponent as BaseExportComponent } from "@bitwarden/angular/tools/export/components/export.component";
|
|
import { EventCollectionService } from "@bitwarden/common/abstractions/event/event-collection.service";
|
|
import { PolicyService } from "@bitwarden/common/admin-console/abstractions/policy/policy.service.abstraction";
|
|
import { UserVerificationService } from "@bitwarden/common/auth/abstractions/user-verification/user-verification.service.abstraction";
|
|
import { BroadcasterService } from "@bitwarden/common/platform/abstractions/broadcaster.service";
|
|
import { CryptoService } from "@bitwarden/common/platform/abstractions/crypto.service";
|
|
import { FileDownloadService } from "@bitwarden/common/platform/abstractions/file-download/file-download.service";
|
|
import { I18nService } from "@bitwarden/common/platform/abstractions/i18n.service";
|
|
import { LogService } from "@bitwarden/common/platform/abstractions/log.service";
|
|
import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service";
|
|
import { VaultExportServiceAbstraction } from "@bitwarden/exporter/vault-export";
|
|
|
|
const BroadcasterSubscriptionId = "ExportComponent";
|
|
|
|
@Component({
|
|
selector: "app-export",
|
|
templateUrl: "export.component.html",
|
|
})
|
|
export class ExportComponent extends BaseExportComponent implements OnInit {
|
|
constructor(
|
|
cryptoService: CryptoService,
|
|
i18nService: I18nService,
|
|
platformUtilsService: PlatformUtilsService,
|
|
exportService: VaultExportServiceAbstraction,
|
|
eventCollectionService: EventCollectionService,
|
|
policyService: PolicyService,
|
|
userVerificationService: UserVerificationService,
|
|
formBuilder: UntypedFormBuilder,
|
|
private broadcasterService: BroadcasterService,
|
|
logService: LogService,
|
|
fileDownloadService: FileDownloadService,
|
|
dialogService: DialogServiceAbstraction
|
|
) {
|
|
super(
|
|
cryptoService,
|
|
i18nService,
|
|
platformUtilsService,
|
|
exportService,
|
|
eventCollectionService,
|
|
policyService,
|
|
window,
|
|
logService,
|
|
userVerificationService,
|
|
formBuilder,
|
|
fileDownloadService,
|
|
dialogService
|
|
);
|
|
}
|
|
|
|
ngOnDestroy() {
|
|
this.broadcasterService.unsubscribe(BroadcasterSubscriptionId);
|
|
}
|
|
|
|
async warningDialog() {
|
|
if (this.encryptedFormat) {
|
|
return await this.dialogService.openSimpleDialog({
|
|
title: { key: "confirmVaultExport" },
|
|
content:
|
|
this.i18nService.t("encExportKeyWarningDesc") +
|
|
os.EOL +
|
|
os.EOL +
|
|
this.i18nService.t("encExportAccountWarningDesc"),
|
|
acceptButtonText: { key: "exportVault" },
|
|
type: SimpleDialogType.WARNING,
|
|
});
|
|
} else {
|
|
return await this.dialogService.openSimpleDialog({
|
|
title: { key: "confirmVaultExport" },
|
|
content: { key: "exportWarningDesc" },
|
|
acceptButtonText: { key: "exportVault" },
|
|
type: SimpleDialogType.WARNING,
|
|
});
|
|
}
|
|
}
|
|
}
|