import * as template from './password-generator.component.html'; import { ToasterService } from 'angular2-toaster'; import { Angulartics2 } from 'angulartics2'; import { Component, EventEmitter, Input, OnInit, Output, } from '@angular/core'; import { PasswordGenerationService } from 'jslib/abstractions/passwordGeneration.service'; import { PlatformUtilsService } from 'jslib/abstractions/platformUtils.service'; @Component({ selector: 'password-generator', template: template, }) export class PasswordGeneratorComponent implements OnInit { @Input() showSelect: boolean = false; @Output() onSelected = new EventEmitter(); options: any = {}; password: string = '-'; showOptions = false; avoidAmbiguous = false; constructor(private passwordGenerationService: PasswordGenerationService, private analytics: Angulartics2, private platformUtilsService: PlatformUtilsService) { } async ngOnInit() { this.options = await this.passwordGenerationService.getOptions(); this.avoidAmbiguous = !this.options.ambiguous; this.password = this.passwordGenerationService.generatePassword(this.options); this.analytics.eventTrack.next({ action: 'Generated Password' }); await this.passwordGenerationService.addHistory(this.password); const slider = document.querySelector('#lengthRange'); if (slider) { // Save password once the slider stop moving. slider.addEventListener('change', async (e) => { e.preventDefault(); this.saveOptions(false); await this.passwordGenerationService.addHistory(this.password); this.analytics.eventTrack.next({ action: 'Regenerated Password' }); }); // Regenerate while slider moving slider.addEventListener('input', (e) => { e.preventDefault(); this.normalizeOptions(); this.password = this.passwordGenerationService.generatePassword(this.options); }); } } async saveOptions(regenerate: boolean = true) { this.normalizeOptions(); await this.passwordGenerationService.saveOptions(this.options); if (regenerate) { this.password = this.passwordGenerationService.generatePassword(this.options); await this.passwordGenerationService.addHistory(this.password); this.analytics.eventTrack.next({ action: 'Regenerated Password' }); } } regenerate() { this.password = this.passwordGenerationService.generatePassword(this.options); this.analytics.eventTrack.next({ action: 'Regenerated Password' }); } copy() { this.analytics.eventTrack.next({ action: 'Copied Generated Password' }); this.platformUtilsService.copyToClipboard(this.password); } select() { this.analytics.eventTrack.next({ action: 'Selected Generated Password' }); this.onSelected.emit(this.password); } toggleOptions() { this.showOptions = !this.showOptions; } private normalizeOptions() { this.options.minLowercase = 0; this.options.minUppercase = 0; this.options.ambiguous = !this.avoidAmbiguous; if (!this.options.uppercase && !this.options.lowercase && !this.options.number && !this.options.special) { this.options.lowercase = true; const lowercase = document.querySelector('#lowercase') as HTMLInputElement; if (lowercase) { lowercase.checked = true; } } if (!this.options.length) { this.options.length = 5; } else if (this.options.length > 128) { this.options.length = 128; } if (!this.options.minNumber) { this.options.minNumber = 0; } else if (this.options.minNumber > this.options.length) { this.options.minNumber = this.options.length; } else if (this.options.minNumber > 9) { this.options.minNumber = 9; } if (!this.options.minSpecial) { this.options.minSpecial = 0; } else if (this.options.minSpecial > this.options.length) { this.options.minSpecial = this.options.length; } else if (this.options.minSpecial > 9) { this.options.minSpecial = 9; } if (this.options.minSpecial + this.options.minNumber > this.options.length) { this.options.minSpecial = this.options.length - this.options.minNumber; } } }