1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-04 18:37:45 +01:00

verify email and outdated browser callouts

This commit is contained in:
Kyle Spearrin 2018-07-12 11:34:51 -04:00
parent 0c61e48977
commit ab4005ae00
6 changed files with 84 additions and 4 deletions

View File

@ -83,6 +83,7 @@ import { TwoFactorVerifyComponent } from './settings/two-factor-verify.component
import { TwoFactorYubiKeyComponent } from './settings/two-factor-yubikey.component'; import { TwoFactorYubiKeyComponent } from './settings/two-factor-yubikey.component';
import { UpdateLicenseComponent } from './settings/update-license.component'; import { UpdateLicenseComponent } from './settings/update-license.component';
import { UserBillingComponent } from './settings/user-billing.component'; import { UserBillingComponent } from './settings/user-billing.component';
import { VerifyEmailComponent } from './settings/verify-email.component';
import { BreachReportComponent } from './tools/breach-report.component'; import { BreachReportComponent } from './tools/breach-report.component';
import { ExportComponent } from './tools/export.component'; import { ExportComponent } from './tools/export.component';
@ -225,6 +226,7 @@ import { SearchPipe } from 'jslib/angular/pipes/search.pipe';
UserBillingComponent, UserBillingComponent,
UserLayoutComponent, UserLayoutComponent,
VaultComponent, VaultComponent,
VerifyEmailComponent,
], ],
entryComponents: [ entryComponents: [
AddEditComponent, AddEditComponent,

View File

@ -0,0 +1,15 @@
<div class="card border-warning">
<div class="card-header bg-warning text-white">
<i class="fa fa-envelope-o fa-fw"></i> {{'verifyEmail' | i18n}}
</div>
<div class="card-body">
<p>{{'verifyEmailDesc' | i18n}}</p>
<button type="button" class="btn btn-block btn-outline-secondary btn-submit" #sendBtn [appApiAction]="actionPromise" [disabled]="sendBtn.loading"
(click)="send()">
<i class="fa fa-spin fa-spinner"></i>
<span>
{{'sendEmail' | i18n}}
</span>
</button>
</div>
</div>

View File

@ -0,0 +1,31 @@
import { Component } from '@angular/core';
import { ToasterService } from 'angular2-toaster';
import { Angulartics2 } from 'angulartics2';
import { ApiService } from 'jslib/abstractions/api.service';
import { I18nService } from 'jslib/abstractions/i18n.service';
@Component({
selector: 'app-verify-email',
templateUrl: 'verify-email.component.html',
})
export class VerifyEmailComponent {
actionPromise: Promise<any>;
constructor(private apiService: ApiService, private i18nService: I18nService,
private analytics: Angulartics2, private toasterService: ToasterService) { }
async send() {
if (this.actionPromise != null) {
return;
}
try {
this.actionPromise = this.apiService.postAccountVerifyEmail();
await this.actionPromise;
this.analytics.eventTrack.next({ action: 'Sent Verification Email' });
this.toasterService.popAsync('success', null, this.i18nService.t('checkInboxForVerification'));
} catch { }
this.actionPromise = null;
}
}

View File

@ -49,12 +49,19 @@
</app-vault-ciphers> </app-vault-ciphers>
</div> </div>
<div class="col-3"> <div class="col-3">
<div class="card"> <app-verify-email *ngIf="showVerifyEmail" class="d-block mb-4"></app-verify-email>
<div class="card border-warning mb-4" *ngIf="showBrowserOutdated">
<div class="card-header bg-warning text-white">
<i class="fa fa-warning fa-fw"></i> {{'updateBrowser' | i18n}}
</div>
<div class="card-body"> <div class="card-body">
Some callout <p>{{'updateBrowserDesc' | i18n}}</p>
<a class="btn btn-block btn-outline-secondary" target="_blank" href="https://browser-update.org/update-browser.html" rel="noopener">
{{'updateBrowser' | i18n}}
</a>
</div> </div>
</div> </div>
<div class="card mt-3"> <div class="card">
<div class="card-header"> <div class="card-header">
{{'organizations' | i18n}} {{'organizations' | i18n}}
</div> </div>

View File

@ -30,7 +30,9 @@ import { GroupingsComponent } from './groupings.component';
import { ShareComponent } from './share.component'; import { ShareComponent } from './share.component';
import { I18nService } from 'jslib/abstractions/i18n.service'; import { I18nService } from 'jslib/abstractions/i18n.service';
import { StorageService } from 'jslib/abstractions/storage.service';
import { SyncService } from 'jslib/abstractions/sync.service'; import { SyncService } from 'jslib/abstractions/sync.service';
import { TokenService } from 'jslib/abstractions/token.service';
@Component({ @Component({
selector: 'app-vault', selector: 'app-vault',
@ -53,14 +55,22 @@ export class VaultComponent implements OnInit {
type: CipherType = null; type: CipherType = null;
folderId: string = null; folderId: string = null;
collectionId: string = null; collectionId: string = null;
showVerifyEmail = false;
showBrowserOutdated = false;
showUpdateKey = false;
private modal: ModalComponent = null; private modal: ModalComponent = null;
constructor(private syncService: SyncService, private route: ActivatedRoute, constructor(private syncService: SyncService, private route: ActivatedRoute,
private router: Router, private location: Location, private router: Router, private location: Location,
private i18nService: I18nService, private componentFactoryResolver: ComponentFactoryResolver) { } private i18nService: I18nService, private componentFactoryResolver: ComponentFactoryResolver,
private tokenService: TokenService, private storageService: StorageService) { }
async ngOnInit() { async ngOnInit() {
this.showVerifyEmail = !(await this.tokenService.getEmailVerified());
this.showBrowserOutdated = window.navigator.userAgent.indexOf('MSIE') !== -1;
this.showUpdateKey = !this.showVerifyEmail && (await this.storageService.get<string>('encKey')) == null;
this.route.queryParams.subscribe(async (params) => { this.route.queryParams.subscribe(async (params) => {
await this.syncService.fullSync(false); await this.syncService.fullSync(false);
await Promise.all([ await Promise.all([

View File

@ -2086,5 +2086,20 @@
}, },
"endDate": { "endDate": {
"message": "End Date" "message": "End Date"
},
"verifyEmail": {
"message": "Verify Email"
},
"verifyEmailDesc": {
"message": "Verify your account's email address to unlock access to all features."
},
"checkInboxForVerification": {
"message": "Check your email inbox for a verification link."
},
"updateBrowser": {
"message": "Update Browser"
},
"updateBrowserDesc": {
"message": "You are using an unsupported web browser. The web vault may not function properly."
} }
} }