import { catchError, tap } from 'rxjs/operators' import { HttpClient } from '@angular/common/http' import { Injectable } from '@angular/core' import { RestExtractor, UserService } from '@app/core' import { UserRegister } from '@shared/models' @Injectable() export class UserSignupService { constructor ( private authHttp: HttpClient, private restExtractor: RestExtractor, private userService: UserService ) { } signup (userCreate: UserRegister) { return this.authHttp.post(UserService.BASE_USERS_URL + 'register', userCreate) .pipe( tap(() => this.userService.setSignupInThisSession(true)), catchError(err => this.restExtractor.handleError(err)) ) } verifyEmail (userId: number, verificationString: string, isPendingEmail: boolean) { const url = `${UserService.BASE_USERS_URL}/${userId}/verify-email` const body = { verificationString, isPendingEmail } return this.authHttp.post(url, body) .pipe(catchError(res => this.restExtractor.handleError(res))) } askSendVerifyEmail (email: string) { const url = UserService.BASE_USERS_URL + '/ask-send-verify-email' return this.authHttp.post(url, { email }) .pipe(catchError(err => this.restExtractor.handleError(err))) } getNewUsername (oldDisplayName: string, newDisplayName: string, currentUsername: string) { // Don't update display name, the user seems to have changed it if (this.displayNameToUsername(oldDisplayName) !== currentUsername) return currentUsername return this.displayNameToUsername(newDisplayName) } private displayNameToUsername (displayName: string) { if (!displayName) return '' return displayName .toLowerCase() .replace(/\s/g, '_') .replace(/[^a-z0-9_.]/g, '') } }