ngx-firebase-cms
Version:
Angular Content Management System using Google Firebase (Authentication, Storage & Firestore)
351 lines • 33.5 kB
JavaScript
/**
* @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"]}