From 15d6e4937f26d9e679978042a6d494c2db1fa8f3 Mon Sep 17 00:00:00 2001 From: Kyle Spearrin Date: Fri, 29 Jun 2018 08:21:08 -0400 Subject: [PATCH] changed breach report to allow username entry --- jslib | 2 +- src/app/tools/breach-report.component.html | 22 +++++++++++++++++----- src/app/tools/breach-report.component.ts | 18 ++++++++++++------ src/locales/en/messages.json | 18 ++++++++++++------ 4 files changed, 42 insertions(+), 18 deletions(-) diff --git a/jslib b/jslib index 93edd272dd..e297f39bd5 160000 --- a/jslib +++ b/jslib @@ -1 +1 @@ -Subproject commit 93edd272dde1d0d5739c29a57668849fb445eee3 +Subproject commit e297f39bd53db6939bc888e5aa1c41ff8579b19d diff --git a/src/app/tools/breach-report.component.html b/src/app/tools/breach-report.component.html index 3bebc6d0b3..5f90854480 100644 --- a/src/app/tools/breach-report.component.html +++ b/src/app/tools/breach-report.component.html @@ -2,15 +2,27 @@

{{'dataBreachReport' | i18n}}

{{'breachDesc' | i18n}}

- - +
+
+
+ + + {{'breachCheckUsernameEmail' | i18n}} +
+
+ +
+

{{'reportError' | i18n}}...

- {{'breachEmailNotFound' | i18n : email}} + {{'breachUsernameNotFound' | i18n : checkedUsername}} - {{'breachEmailFound' | i18n : email : breachedAccounts.length}} + {{'breachUsernameFound' | i18n : checkedUsername : breachedAccounts.length}}
  • @@ -42,4 +54,4 @@
- +
diff --git a/src/app/tools/breach-report.component.ts b/src/app/tools/breach-report.component.ts index f04bbf4e87..8efddd950a 100644 --- a/src/app/tools/breach-report.component.ts +++ b/src/app/tools/breach-report.component.ts @@ -12,21 +12,27 @@ import { BreachAccountResponse } from 'jslib/models/response/breachAccountRespon templateUrl: 'breach-report.component.html', }) export class BreachReportComponent implements OnInit { - loading = true; error = false; - email: string; + username: string; + checkedUsername: string; breachedAccounts: BreachAccountResponse[] = []; + formPromise: Promise; constructor(private auditService: AuditService, private userService: UserService) { } async ngOnInit() { - this.loading = true; + this.username = await this.userService.getEmail(); + } + + async submit() { + this.error = false; + this.username = this.username.toLowerCase(); try { - this.email = await this.userService.getEmail(); - this.breachedAccounts = await this.auditService.breachedAccounts(this.email); + this.formPromise = this.auditService.breachedAccounts(this.username); + this.breachedAccounts = await this.formPromise; } catch { this.error = true; } - this.loading = false; + this.checkedUsername = this.username; } } diff --git a/src/locales/en/messages.json b/src/locales/en/messages.json index 6cebae60c5..3d4bf27212 100644 --- a/src/locales/en/messages.json +++ b/src/locales/en/messages.json @@ -1148,10 +1148,16 @@ "breachDesc": { "message": "A \"breach\" is an incident where a site's data has been illegally accessed by hackers and then released publicly. Review the types of data that were compromised (email addresses, passwords, credit cards etc.) and take appropriate action, such as changing passwords." }, - "breachEmailNotFound": { - "message": "Your email ($EMAIL$) was not found in any known data breaches.", + "breachCheckUsernameEmail": { + "message": "Check any usernames or email addresses that you use." + }, + "checkBreaches": { + "message": "Check Breaches" + }, + "breachUsernameNotFound": { + "message": "$USERNAME$ was not found in any known data breaches.", "placeholders": { - "email": { + "username": { "content": "$1", "example": "user@example.com" } @@ -1161,10 +1167,10 @@ "message": "Good News", "description": "ex. Good News, No Breached Accounts Found!" }, - "breachEmailFound": { - "message": "Your email ($EMAIL$) was found in $COUNT$ different data breaches online.", + "breachUsernameFound": { + "message": "$USERNAME$ was found in $COUNT$ different data breaches online.", "placeholders": { - "email": { + "username": { "content": "$1", "example": "user@example.com" },