UNPKG

ngx-firebase-cms

Version:

Angular Content Management System using Google Firebase (Authentication, Storage & Firestore)

351 lines 33.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, ViewChild, HostListener } from '@angular/core'; import { UnsubscriptionService } from '../../service/unsubscription.service'; import { FormBuilder, FormControl, Validators } from '@angular/forms'; import { AngularFireAuth } from '@angular/fire/auth'; import { NzMessageService, NzNotificationService } from 'ng-zorro-antd'; import { AngularFireStorage } from '@angular/fire/storage'; import { AuthService } from '../../service/auth.service'; import { HelperService } from '../../service/helper.service'; import * as firebase from 'firebase/app'; import { of } from 'rxjs'; import { AngularFirestore } from '@angular/fire/firestore'; export class ProfileComponent { /** * @param {?} unsubscription * @param {?} afAuth * @param {?} afs * @param {?} message * @param {?} storage * @param {?} auth * @param {?} fb * @param {?} notification * @param {?} helper */ constructor(unsubscription, afAuth, afs, message, storage, auth, fb, notification, helper) { this.unsubscription = unsubscription; this.afAuth = afAuth; this.afs = afs; this.message = message; this.storage = storage; this.auth = auth; this.fb = fb; this.notification = notification; this.helper = helper; this.titlebar = { title: "Profile", description: "Edit your profile", breadcrumbs: [ { title: "Profile", icon: 'team' } ] }; this.showChangePassword = false; this.isLoading = false; this.showDisplayName = false; this.profileURL = null; this.beforeUpload = (/** * @param {?} file * @return {?} */ (file) => { if (file['type'] != "image/jpeg") { this.message.error("File type should be JPEG"); return false; } else if (file['size'] / 1024 / 1024 > 1) { this.message.error("File size should be less than 1 Mb"); return false; } else { return true; } }); this.uploadProfilePic = (/** * @param {?} item * @return {?} */ (item) => { this.message.success(`File is uploading`); /** @type {?} */ let timestamp = new Date().valueOf(); /** @type {?} */ let filePath = `/profile/${timestamp}.jpeg`; /** @type {?} */ let file = item['file']; /** @type {?} */ const task = this.storage.upload(filePath, file) .then((/** * @param {?} res * @return {?} */ res => { return this.storage.ref(filePath).getDownloadURL().toPromise(); })) .then((/** * @param {?} res * @return {?} */ res => { return this.afs.collection("users").doc(this.auth.uid).update({ "profileURL": res, "uploadTime": firebase.firestore.FieldValue.serverTimestamp() }); })) .then((/** * @param {?} res * @return {?} */ res => { this.auth.log(`changed profile pic ${timestamp}.jpeg`); this.message.success("File Uploaded"); })).catch((/** * @param {?} err * @return {?} */ err => { this.message.error(err); })); return of().subscribe((/** * @param {?} event * @return {?} */ (event) => { if (event['percent'] != 100) { item.onProgress(event, item.file); } else { item.onSuccess(event['body'], item.file, event); } }), (/** * @param {?} err * @return {?} */ (err) => { item.onError(err, item.file); })); }); } /** * @return {?} */ ngOnInit() { this.sub = this.auth.user$.subscribe((/** * @param {?} res * @return {?} */ res => { this.profileURL = res.profileURL; }), (/** * @param {?} err * @return {?} */ err => { })); this.initForm(); } /** * @return {?} */ ngOnDestroy() { this.sub.unsubscribe(); } /** * @return {?} */ initForm() { this.passwordForm = this.fb.group({ "previousPassword": new FormControl({ value: "", disabled: false }, [Validators.required]), "newPassword": new FormControl({ value: "", disabled: false }, [Validators.required]), }); this.displayNameForm = this.fb.group({ "displayName": new FormControl({ "value": this.auth.displayName, disabled: false }, [Validators.required]) }); } /** * @return {?} */ changePassword() { if (typeof this.passwordForm.value["newPassword"] == "string") this.passwordForm.controls["newPassword"].setValue(this.passwordForm.value["newPassword"].trim()); if (this.passwordForm.valid && !this.isLoading) { this.isLoading = true; this.afAuth.auth.signInWithEmailAndPassword(this.auth.email, this.passwordForm.value['previousPassword']).then((/** * @param {?} res * @return {?} */ res => { /** @type {?} */ let user = this.afAuth.auth.currentUser; return user.updatePassword(this.passwordForm.value["newPassword"]); })) .then((/** * @param {?} res * @return {?} */ res => { this.auth.log(` updated the password`); this.message.success(`Change the password`); this.showChangePassword = !this.showChangePassword; })) .catch((/** * @param {?} err * @return {?} */ err => { this.message.error(err); })); } else { this.passwordForm.controls["newPassword"].markAsDirty(); } } /** * @return {?} */ changeDisplayName() { if (typeof this.displayNameForm.value["displayName"] == "string") this.displayNameForm.controls["displayName"].setValue(this.displayNameForm.value["displayName"].trim()); if (this.displayNameForm.valid && !this.isLoading) { this.isLoading = true; this.afs.collection("users").doc(this.auth.uid).update({ "displayName": this.displayNameForm.value["displayName"], "uploadTime": firebase.firestore.FieldValue.serverTimestamp() }).then((/** * @param {?} res * @return {?} */ res => { this.isLoading = false; this.showDisplayName = !this.showDisplayName; })); } else { this.displayNameForm.controls["displayName"].markAsDirty(); } } /** * @return {?} */ getProfilePic() { return (this.profileURL) ? { 'background-image': 'url(\'' + this.profileURL + '\')' } : {}; } /** * @param {?} e * @return {?} */ keyboardEvent(e) { if (this.showChangePassword && e.key == 'Escape') { this.notification.blank("ESC", "Escape modal"); this.showChangePassword = false; } if (this.showDisplayName && e.key == 'Escape') { this.notification.blank("ESC", "Escape modal"); this.showDisplayName = false; } if (this.showChangePassword) { if (e.ctrlKey && e.key == 'Enter') { this.notification.blank("⌃ ENTER", "Form Submission"); this.changePassword(); } } if (this.showDisplayName && e.ctrlKey && e.key == 'Enter') { this.notification.blank("⌃ ENTER", "Form Submission"); this.changeDisplayName(); } } } ProfileComponent.decorators = [ { type: Component, args: [{ selector: 'aq-profile', template: "<aq-title-bar [data]=\"titlebar\"></aq-title-bar>\n\n<div class=\"container\">\n <h3>{{ (auth.user$ | async)?.displayName }}</h3>\n <p>Email: {{ (auth.user$ | async)?.email }}</p>\n <p>Roles: {{ (auth.user$ | async)?.roles }}</p>\n <p>Created on: {{ (auth.user$ | async)?.createdTime.toDate() | date: 'medium' }}</p>\n <p>Last login: {{ auth.lastLogin | date: 'medium' }}</p>\n\n <button class=\"m-r-10\" nz-tooltip nzTitle=\"Change Password\" nz-button (click)=\"showChangePassword=true\">\n <i nz-icon type=\"security-scan\" theme=\"outline\"></i> Password\n </button>\n\n <button class=\"m-r-10\" nz-tooltip nzTitle=\"Change Display Name\" nz-button (click)=\"showDisplayName=true\">\n <i nz-icon type=\"font-colors\" theme=\"outline\"></i> Display Name\n </button>\n\n <nz-upload class=\"m-r-10\" [nzBeforeUpload]=\"beforeUpload\" [nzCustomRequest]=\"uploadProfilePic\"\n [nzShowUploadList]=\"false\">\n <button #uploadButton nz-tooltip nzTitle=\"Change Profile Image\" nz-button>\n <i nz-icon type=\"picture\" theme=\"outline\"></i> Profile Image\n </button>\n </nz-upload>\n</div>\n\n<nz-drawer nzWidth=\"100%\" [nzVisible]=\"showChangePassword\" nzTitle=\"Change Password\" (nzOnClose)=\"showChangePassword = !showChangePassword\">\n <form nz-form [formGroup]=\"passwordForm\" (ngSubmit)=\"changePassword()\">\n <nz-form-item>\n <nz-form-control>\n <label>Previous Password</label>\n <input type=\"password\" nz-input formControlName=\"previousPassword\" placeholder=\"Previous Password\"\n autocomplete=\"password\" autofocus>\n <nz-form-explain\n *ngIf=\"passwordForm.get('previousPassword').dirty && passwordForm.get('previousPassword').errors\">\n Please input\n your previous password!</nz-form-explain>\n </nz-form-control>\n </nz-form-item>\n <nz-form-item>\n <nz-form-control>\n <label>New Password</label>\n <input type=\"password\" nz-input formControlName=\"newPassword\" placeholder=\"New Password\" autocomplete=\"password\" autofocus>\n <nz-form-explain\n *ngIf=\"passwordForm.get('newPassword').dirty && passwordForm.get('newPassword').errors\">Please input\n your new\n password!</nz-form-explain>\n </nz-form-control>\n </nz-form-item>\n </form>\n <div class=\"footer\">\n <button type=\"button\" (click)=\"changePassword()\" class=\"ant-btn ant-btn-primary\">Submit </button>\n <button type=\"button\" (click)=\"showChangePassword = !showChangePassword\" class=\"ant-btn\">Cancel </button>\n </div>\n</nz-drawer>\n\n<nz-drawer nzWidth=\"100%\" [nzVisible]=\"showDisplayName\" nzTitle=\"Change Display Name\" (nzOnClose)=\"showDisplayName = !showDisplayName\">\n <form nz-form [formGroup]=\"displayNameForm\" (ngSubmit)=\"changeDisplayName()\">\n <nz-form-item>\n <nz-form-control>\n <label>Your Display Name</label>\n <input type=\"text\" nz-input formControlName=\"displayName\" placeholder=\"Please enter your display name\"\n autocomplete=\"displayName\" autofocus>\n <nz-form-explain\n *ngIf=\"displayNameForm.get('displayName').dirty && displayNameForm.get('displayName').errors\">Please\n input\n your Display Name!</nz-form-explain>\n </nz-form-control>\n </nz-form-item>\n </form>\n <div class=\"footer\">\n <button type=\"button\" (click)=\"changeDisplayName()\" class=\"ant-btn ant-btn-primary\">Submit </button>\n <button type=\"button\" (click)=\"showDisplayName = !showDisplayName\" class=\"ant-btn\">Cancel </button>\n </div>\n</nz-drawer>\n", styles: [".img-rounded{border-radius:50%;width:80%;position:relative}.img-rounded:hover{opacity:1}.footer{position:absolute;bottom:0;width:100%;border-top:1px solid #e8e8e8;padding:10px 16px;left:0;z-index:9999;background:#fff}.footer button{margin-left:10px}.m-r-10{margin-right:10px}.w-200{width:200px}.user-profile{width:200px;height:200px;background:0 0/cover #efefef;border-radius:50%}"] }] } ]; /** @nocollapse */ ProfileComponent.ctorParameters = () => [ { type: UnsubscriptionService }, { type: AngularFireAuth }, { type: AngularFirestore }, { type: NzMessageService }, { type: AngularFireStorage }, { type: AuthService }, { type: FormBuilder }, { type: NzNotificationService }, { type: HelperService } ]; ProfileComponent.propDecorators = { uploadButton: [{ type: ViewChild, args: ['uploadButton',] }], keyboardEvent: [{ type: HostListener, args: ['document:keydown', ['$event'],] }] }; if (false) { /** @type {?} */ ProfileComponent.prototype.uploadButton; /** @type {?} */ ProfileComponent.prototype.titlebar; /** @type {?} */ ProfileComponent.prototype.showChangePassword; /** @type {?} */ ProfileComponent.prototype.passwordForm; /** @type {?} */ ProfileComponent.prototype.displayNameForm; /** @type {?} */ ProfileComponent.prototype.isLoading; /** @type {?} */ ProfileComponent.prototype.showDisplayName; /** @type {?} */ ProfileComponent.prototype.profileURL; /** @type {?} */ ProfileComponent.prototype.sub; /** @type {?} */ ProfileComponent.prototype.beforeUpload; /** @type {?} */ ProfileComponent.prototype.uploadProfilePic; /** * @type {?} * @private */ ProfileComponent.prototype.unsubscription; /** * @type {?} * @private */ ProfileComponent.prototype.afAuth; /** * @type {?} * @private */ ProfileComponent.prototype.afs; /** * @type {?} * @private */ ProfileComponent.prototype.message; /** * @type {?} * @private */ ProfileComponent.prototype.storage; /** @type {?} */ ProfileComponent.prototype.auth; /** * @type {?} * @private */ ProfileComponent.prototype.fb; /** * @type {?} * @private */ ProfileComponent.prototype.notification; /** * @type {?} * @private */ ProfileComponent.prototype.helper; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile.component.js","sourceRoot":"ng://ngx-firebase-cms/","sources":["lib/component/profile/profile.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, ViewChild, HostListener } from '@angular/core';\nimport { Breadcrumb } from '../../interface/breadcrumb';\nimport { UnsubscriptionService } from '../../service/unsubscription.service';\nimport { FormGroup, FormBuilder, FormControl, Validators } from '@angular/forms';\nimport { AngularFireAuth } from '@angular/fire/auth';\nimport { NzMessageService, NzNotificationService, UploadXHRArgs, UploadFile } from 'ng-zorro-antd';\nimport { AngularFireStorage } from '@angular/fire/storage';\nimport { AuthService } from '../../service/auth.service';\nimport { HelperService } from '../../service/helper.service';\nimport * as firebase from 'firebase/app';\nimport { HttpEvent } from '@angular/common/http';\nimport { of } from 'rxjs';\nimport { AngularFirestore } from '@angular/fire/firestore';\nimport { Titlebar } from '../../interface/titlebar';\n\n@Component({\n  selector: 'aq-profile',\n  templateUrl: './profile.component.html',\n  styleUrls: ['./profile.component.css']\n})\nexport class ProfileComponent implements OnInit {\n  @ViewChild('uploadButton') uploadButton: ElementRef\n\n  titlebar: Titlebar = {\n    title: \"Profile\",\n    description: \"Edit your profile\",\n    breadcrumbs: [\n      {\n        title: \"Profile\",\n        icon: 'team'\n      }\n    ]\n  }\n\n  showChangePassword = false\n  passwordForm: FormGroup\n  displayNameForm: FormGroup\n  isLoading = false\n  showDisplayName = false\n  profileURL = null\n  sub\n\n  constructor(\n    private unsubscription: UnsubscriptionService,\n    private afAuth: AngularFireAuth,\n    private afs: AngularFirestore,\n    private message: NzMessageService,\n    private storage: AngularFireStorage,\n    public auth: AuthService,\n    private fb: FormBuilder,\n    private notification: NzNotificationService,\n    private helper: HelperService\n  ) { }\n\n  ngOnInit() {\n    this.sub = this.auth.user$.subscribe(res => {\n      this.profileURL = res.profileURL\n    }, err => {})\n    this.initForm()\n  }\n\n  ngOnDestroy() {\n    this.sub.unsubscribe()\n  }\n\n  initForm() {\n    this.passwordForm = this.fb.group({\n      \"previousPassword\": new FormControl({ value: \"\", disabled: false }, [Validators.required]),\n      \"newPassword\": new FormControl({ value: \"\", disabled: false }, [Validators.required]),\n    })\n    this.displayNameForm = this.fb.group({\n      \"displayName\": new FormControl({ \"value\": this.auth.displayName, disabled: false }, [Validators.required])\n    })\n  }\n\n  changePassword() {\n    if (typeof this.passwordForm.value[\"newPassword\"] == \"string\") this.passwordForm.controls[\"newPassword\"].setValue(this.passwordForm.value[\"newPassword\"].trim())\n    if (this.passwordForm.valid && !this.isLoading) {\n      this.isLoading = true\n      this.afAuth.auth.signInWithEmailAndPassword(this.auth.email, this.passwordForm.value['previousPassword']).then(res => {\n        let user = this.afAuth.auth.currentUser\n        return user.updatePassword(this.passwordForm.value[\"newPassword\"])\n      })\n        .then(res => {\n          this.auth.log(` updated the password`)\n          this.message.success(`Change the password`)\n          this.showChangePassword = !this.showChangePassword\n        })\n        .catch(err => {\n          this.message.error(err)\n        })\n    } else {\n      this.passwordForm.controls[\"newPassword\"].markAsDirty()\n    }\n  }\n\n  changeDisplayName() {\n    if (typeof this.displayNameForm.value[\"displayName\"] == \"string\") this.displayNameForm.controls[\"displayName\"].setValue(this.displayNameForm.value[\"displayName\"].trim())\n    if (this.displayNameForm.valid && !this.isLoading) {\n      this.isLoading = true\n      this.afs.collection(\"users\").doc(this.auth.uid).update({\n        \"displayName\": this.displayNameForm.value[\"displayName\"],\n        \"uploadTime\": firebase.firestore.FieldValue.serverTimestamp()\n      }).then(res => {\n        this.isLoading = false\n        this.showDisplayName = !this.showDisplayName\n      })\n    } else {\n      this.displayNameForm.controls[\"displayName\"].markAsDirty()\n    }\n  }\n\n  beforeUpload = (file: UploadFile): boolean => {\n    if (file['type'] != \"image/jpeg\") {\n      this.message.error(\"File type should be JPEG\")\n      return false\n    } else if (file['size'] / 1024 / 1024 > 1) {\n      this.message.error(\"File size should be less than 1 Mb\")\n      return false\n    } else {\n      return true\n    }\n  }\n\n  uploadProfilePic = (item: UploadXHRArgs) => {\n    this.message.success(`File is uploading`)\n    let timestamp = new Date().valueOf()\n    let filePath = `/profile/${timestamp}.jpeg`\n    let file = item['file']\n    const task = this.storage.upload(filePath, file)\n      .then(res => {\n        return this.storage.ref(filePath).getDownloadURL().toPromise()\n      })\n      .then(res => {\n        return this.afs.collection(\"users\").doc(this.auth.uid).update({\n          \"profileURL\": res,\n          \"uploadTime\": firebase.firestore.FieldValue.serverTimestamp()\n        })\n      })\n      .then(res => {\n        this.auth.log(`changed profile pic ${timestamp}.jpeg`)\n        this.message.success(\"File Uploaded\")\n      }).catch(err => {\n        this.message.error(err)\n      })\n    return of().subscribe((event: HttpEvent<{}>) => {\n      if (event['percent'] != 100) {\n        item.onProgress(event, item.file);\n      } else {\n        item.onSuccess(event['body'], item.file, event);\n      }\n    }, (err) => {\n      item.onError(err, item.file);\n    })\n  }\n\n  getProfilePic() {\n    return (this.profileURL) ? { 'background-image': 'url(\\'' + this.profileURL + '\\')' } : {}\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  keyboardEvent(e: KeyboardEvent) {\n    if (this.showChangePassword && e.key == 'Escape') {\n      this.notification.blank(\"ESC\", \"Escape modal\")\n      this.showChangePassword = false\n    }\n\n    if (this.showDisplayName && e.key == 'Escape') {\n      this.notification.blank(\"ESC\", \"Escape modal\")\n      this.showDisplayName = false\n    }\n\n    if (this.showChangePassword) {\n      if (e.ctrlKey && e.key == 'Enter') {\n        this.notification.blank(\"⌃ ENTER\", \"Form Submission\")\n        this.changePassword()\n      }\n    }\n    \n    if (this.showDisplayName && e.ctrlKey && e.key == 'Enter') {\n      this.notification.blank(\"⌃ ENTER\", \"Form Submission\")\n      this.changeDisplayName()\n    }\n  }\n}\n"]}