From c0a20f59086cb596bc161ab4997915c68b6553e5 Mon Sep 17 00:00:00 2001 From: "k.triantafyllou" Date: Fri, 23 Apr 2021 16:27:37 +0000 Subject: [PATCH] [Connect | Trunk]: Add subscriber invite module from library git-svn-id: https://svn.driver.research-infrastructures.eu/driver/dnet40/modules/uoa-connect-portal/trunk@60969 d315682c-612b-4755-9ff5-7f18f6832af3 --- src/app/app.component.ts | 12 +- .../subscribe/invite/invite.component.html | 194 ++----------- .../subscribe/invite/invite.component.ts | 273 ++---------------- .../subscribe/invite/inviteBasic.module.ts | 13 +- .../utils/subscribe/subscribe.component.ts | 8 +- src/assets/connect-custom.css | 11 +- 6 files changed, 78 insertions(+), 433 deletions(-) diff --git a/src/app/app.component.ts b/src/app/app.component.ts index 9192a07..5ae4f71 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -56,9 +56,9 @@ import {SmoothScroll} from "./openaireLibrary/utils/smooth-scroll"; -
- - +
+ +
@@ -86,14 +86,11 @@ import {SmoothScroll} from "./openaireLibrary/utils/smooth-scroll"; }) export class AppComponent { isClient: boolean = false; - userMenuItems: MenuItem[] = []; - - menuItems: RootMenuItem [] = []; bottomMenuItems: MenuItem[] = []; public community = null; - properties: EnvProperties; + properties: EnvProperties = properties; showMenu: boolean = false; communities = null; user: User; @@ -122,7 +119,6 @@ export class AppComponent { } ngOnInit() { - this.properties = properties; this._communitiesService.updateCommunities(this.properties, this.properties.communitiesAPI); if (typeof document !== 'undefined') { try { diff --git a/src/app/utils/subscribe/invite/invite.component.html b/src/app/utils/subscribe/invite/invite.component.html index 3505060..75a209d 100644 --- a/src/app/utils/subscribe/invite/invite.component.html +++ b/src/app/utils/subscribe/invite/invite.component.html @@ -1,139 +1,22 @@ - -
-
+
+
- -
+
-
-
Invite users to subscribe
-
- +
+
Invite users to subscribe
+
+
- - - - -
- - - - - - - - - - - - -
From * : - - -
Please add your name. -
-
To * : - - -
- separate multiple emails with a comma -
-
Please add - valid email/s. -
-
Please add a recipient. -
-
-
- - - - - - - - - - - - -
Message: - - - - - - - - - - -
-
- - {{body.signature}} - - {{body.fromMessage}}... - - - {{body.fromMessage}} - {{body.fromName}} - -
www.openaire.eu -
+
+ +
+ Cancel +
- - - - - - - - - - - -
-
* - Required fields -
-
-
- -
-
- -
- - Back - -
-
- -
-
- -
- - - - - -
Please add - valid email/s. -
-
Please add a recipient. -
- -
separate with commas
-
- - {{" "}} - - - - - - Customize - +
+
+ +
+ Customize + + + +
diff --git a/src/app/utils/subscribe/invite/invite.component.ts b/src/app/utils/subscribe/invite/invite.component.ts index 0d85c0e..be271da 100644 --- a/src/app/utils/subscribe/invite/invite.component.ts +++ b/src/app/utils/subscribe/invite/invite.component.ts @@ -1,121 +1,59 @@ import {Component, Input, OnInit} from '@angular/core'; -import {FormBuilder} from "@angular/forms"; import {ActivatedRoute, Router} from '@angular/router'; -import {ConnectHelper} from '../../../openaireLibrary/connect/connectHelper'; - -import {Email} from '../../../openaireLibrary/utils/email/email'; -import {Body} from '../../../openaireLibrary/utils/email/body'; -import {Validator} from '../../../openaireLibrary/utils/email/validator'; -import {Composer} from '../../../openaireLibrary/utils/email/composer'; - import {EnvProperties} from '../../../openaireLibrary/utils/properties/env-properties'; -import {EmailService} from '../../../openaireLibrary/utils/email/email.service'; -import {CommunityService} from "../../../openaireLibrary/connect/community/community.service"; -import {ErrorCodes} from '../../../openaireLibrary/utils/properties/errorCodes'; -import {ErrorMessagesComponent} from '../../../openaireLibrary/utils/errorMessages.component'; -import {Session, User} from '../../../openaireLibrary/login/utils/helper.class'; -import {HelperFunctions} from "../../../openaireLibrary/utils/HelperFunctions.class"; +import {User} from '../../../openaireLibrary/login/utils/helper.class'; import {HelperService} from "../../../openaireLibrary/utils/helper/helper.service"; import {Meta, Title} from "@angular/platform-browser"; import {SEOService} from "../../../openaireLibrary/sharedComponents/SEO/SEO.service"; import {PiwikService} from "../../../openaireLibrary/utils/piwik/piwik.service"; -import {PiwikHelper} from "../../piwikHelper"; import {UserManagementService} from "../../../openaireLibrary/services/user-management.service"; import {Breadcrumb} from "../../../openaireLibrary/utils/breadcrumbs/breadcrumbs.component"; import {Subscriber, Subscription} from "rxjs"; import {properties} from "../../../../environments/environment"; +declare var UIkit; + @Component({ selector: 'invite', templateUrl: './invite.component.html', }) - export class InviteComponent implements OnInit { - @Input() longView: boolean = true; @Input() communityId = null; - @Input() buttonSizeSmall = true; - - @Input() properties: EnvProperties; - - public community = null; - //public showLoading: boolean = true; - public errorMessage: string = ''; - public successfulSentMessage: string = ''; - public successfulSentRecipients: string[] = []; - public failureSentMessage: string = ''; - public failureSentRecipients: string[] = []; - public inviteErrorMessage: string = ''; - public missingCommunityId: string = ''; - public showAddRecipientMessage: boolean = false; - public showAddNameMessage: boolean = false; - - public email: Email; - public body: Body; - public recipients: string; - public fullname: string; - - public areValid: boolean = true; - - private ckeditorContent: string; - - // public defaultBody =''; - - public communityIdParam = {}; - public status: number = 1; - public errorCodes: ErrorCodes; - private errorMessages: ErrorMessagesComponent; - public pageContents = null; - public divContents = null; - - public url: string = null; + public properties: EnvProperties = properties; public pageTitle: string = "Invite"; - private user: User; - + public user: User; + public url: string; + public pageContents; + public divContents public breadcrumbs: Breadcrumb[] = [{name: 'home', route: '/'}, {name: 'invite'}]; - - subs: Subscription[] = []; - + private subs: Subscription[] = []; + constructor( private route: ActivatedRoute, private _router: Router, - public _fb: FormBuilder, - private _emailService: EmailService, - private _communityService: CommunityService, - private helper: HelperService, private _meta: Meta, + private helper: HelperService, private _title: Title, private seoService: SEOService, private _piwikService: PiwikService, private userManageService: UserManagementService) { - - this.errorCodes = new ErrorCodes(); - this.errorMessages = new ErrorMessagesComponent(); - this.status = this.errorCodes.LOADING; } - + public ngOnInit() { - if(!this.properties) { - this.properties = properties; - } - if(this.properties) { - this.errorMessage = ""; - this.missingCommunityId = ""; - this.status = this.errorCodes.LOADING; - this.subs.push(this.userManageService.getUserInfo().subscribe( - user => { - this.user = user; - this.init(); - }, - error => { - this.init(); - } - )); - //this.init(); - } + this.subs.push(this.userManageService.getUserInfo().subscribe( + user => { + this.user = user; + })); + this.getPageContents(); + this.url = this.properties.domain + this._router.url; + this.seoService.createLinkForCanonicalURL(this.url); + this.updateUrl(this.url ); + this.updateTitle(this.pageTitle); + this.updateDescription("OpenAIRE - Connect, Community Gateway, research community, invite"); } - + ngOnDestroy() { for (let sub of this.subs) { if (sub instanceof Subscriber) { @@ -123,183 +61,36 @@ export class InviteComponent implements OnInit { } } } - - private init() { - this.subs.push(this.route.queryParams.subscribe( - communityId => { - //if(!this.communityId && typeof document !== 'undefined'){ - this.communityId = ConnectHelper.getCommunityFromDomain(this.properties.domain); - if (!this.communityId) { - this.communityId = communityId['communityId']; - } - - if (this.longView) { - if (this.properties.enablePiwikTrack && (typeof document !== 'undefined')) { - this.subs.push(this._piwikService.trackView(this.properties, this.pageTitle, PiwikHelper.getSiteId(this.communityId, this.properties.environment)).subscribe()); - } - this.url = this.properties.domain + this._router.url; - this.seoService.createLinkForCanonicalURL(this.url); - this.updateUrl(this.url); - this.updateTitle(this.pageTitle); - this.updateDescription("OpenAIRE - Connect, Community Gateway, research community, invite"); - } - this.communityIdParam = (this.properties.environment != "development") ? {} : {communityId: this.communityId}; - if (this.communityId != null && this.communityId != '') { - //this.getDivContents(); - this.getPageContents(); - this.subs.push(this._communityService.getCommunityAsObservable().subscribe( - community => { - this.community = community; - this.fullname = (this.user) ? this.user.fullname : null; - //console.log("Fullname from session " + Session.getUserFullName()); - - this.body = Composer.initializeInvitationsBody(this.communityId, this.community.title, this.fullname); - this.email = Composer.initializeInvitationsEmail(community.title); - this.recipients = ""; - - this.status = this.errorCodes.DONE; - }, - error => { - //this.handleError(error) - this.handleError("Error getting community with id: " + this.communityId, error); - this.status = this.errorMessages.getErrorCode(error.status); - } - )); - } else { - this.status = this.errorCodes.DONE; - this.missingCommunityId = "There is no community selected!"; - } - - })); - } - + private getPageContents() { this.subs.push(this.helper.getPageHelpContents(this.properties, this.communityId, this._router.url).subscribe(contents => { this.pageContents = contents; })); } - + private getDivContents() { this.subs.push(this.helper.getDivHelpContents(this.properties, this.communityId, this._router.url).subscribe(contents => { this.divContents = contents; })); } - - - public invite() { - this.successfulSentMessage = ""; - this.failureSentMessage = ""; - this.inviteErrorMessage = ""; - this.status = this.errorCodes.LOADING; - HelperFunctions.scroll(); - if (!this.isEmpty(this.recipients) && this.body.fromName != "") { - if (this.validateEmails()) { - this.composeEmail(); - - this.subs.push(this._emailService.sendEmail(this.properties, this.email).subscribe( - res => { - this.status = this.errorCodes.DONE; - if (res['success']) { - this.successfulSentMessage = "Email sent successfully to: "; - this.successfulSentRecipients = res['success']; - } - if (res['failure']) { - this.failureSentMessage = "There was an error sending email to: "; - this.failureSentRecipients = res['failure']; - } - - this.body = Composer.initializeInvitationsBody(this.communityId, this.community.title, this.fullname); - this.email = Composer.initializeInvitationsEmail(this.community.title); - this.recipients = ""; - }, - error => { - //console.log(error); - this.handleError("Error inviting emails: " + JSON.stringify(this.recipients) + " to community with id: " + this.communityId + " by: " + this.fullname, error); - this.status = this.errorCodes.DONE; - this.inviteErrorMessage = "There was an error sending emails. Please try again."; - } - )); - } else { - this.email.recipients = []; - this.status = this.errorCodes.DONE; - } - } else { - this.showAddRecipientMessage = true; - this.status = this.errorCodes.DONE; - } - } - - public isEmpty(data: string): boolean { - return data != undefined && !data.replace(/\s/g, '').length; - } - - public resetMessages() { - this.errorMessage = ""; - this.successfulSentMessage = ""; - this.failureSentMessage = ""; - this.inviteErrorMessage = ""; - } - - public validateEmails(): boolean { - if (this.parseEmails()) { - if (Validator.hasValidEmails(this.email.recipients)) { - return this.areValid; - } - } - this.areValid = false; - return this.areValid; - } - - public parseEmails(): boolean { - let email = new Array(); - - // remove spaces - this.recipients = this.recipients.replace(/\s/g, ''); - - // remove commas - email = this.recipients.split(","); - - // remove empty fields - for (let i = 0; i < email.length; i++) { - if (!(email[i] == "")) { - this.email.recipients.push(email[i]); - } - } - return true; - } - - public composeEmail() { - this.email.body = Composer.formatEmailBodyForInvitation(this.body); - } - allowEdit() { - if (!this.user) { - return false; - } - var email = this.user.email; - var index = -1; - if (email && this.community != null && this.community.managers != null) { - index = this.community.managers.indexOf(email); - } - return Session.isPortalAdministrator(this.user) || Session.isCommunityCurator(this.user) || index != -1; - } - - private handleError(message: string, error) { - console.error("Invite Page (or component): " + message, error); - } - private updateDescription(description: string) { this._meta.updateTag({content: description}, "name='description'"); this._meta.updateTag({content: description}, "property='og:description'"); } - + private updateTitle(title: string) { var _title = ((title.length > 50) ? title.substring(0, 50) : title); this._title.setTitle(_title); this._meta.updateTag({content: _title}, "property='og:title'"); } - + private updateUrl(url: string) { this._meta.updateTag({content: url}, "property='og:url'"); } + + close(element) { + UIkit.dropdown(element).hide(); + this + } } diff --git a/src/app/utils/subscribe/invite/inviteBasic.module.ts b/src/app/utils/subscribe/invite/inviteBasic.module.ts index 77104e8..45715cf 100644 --- a/src/app/utils/subscribe/invite/inviteBasic.module.ts +++ b/src/app/utils/subscribe/invite/inviteBasic.module.ts @@ -16,11 +16,16 @@ import {Schema2jsonldModule} from "../../../openaireLibrary/sharedComponents/sch import {SEOServiceModule} from "../../../openaireLibrary/sharedComponents/SEO/SEOService.module"; import {PiwikService} from "../../../openaireLibrary/utils/piwik/piwik.service"; import {BreadcrumbsModule} from "../../../openaireLibrary/utils/breadcrumbs/breadcrumbs.module"; +import {SubscriberInviteModule} from "../../../openaireLibrary/sharedComponents/subscriber-invite/subscriber-invite.module"; +import {LoadingModule} from "../../../openaireLibrary/utils/loading/loading.module"; +import {IconsService} from "../../../openaireLibrary/utils/icons/icons.service"; +import {cog, send} from "../../../openaireLibrary/utils/icons/icons"; +import {IconsModule} from "../../../openaireLibrary/utils/icons/icons.module"; @NgModule({ imports: [ RouterModule, CommonModule, FormsModule, CKEditorModule, ErrorMessagesModule, - HelperModule, Schema2jsonldModule, SEOServiceModule, BreadcrumbsModule + HelperModule, Schema2jsonldModule, SEOServiceModule, BreadcrumbsModule, SubscriberInviteModule, LoadingModule, IconsModule ], declarations: [ InviteComponent @@ -35,4 +40,8 @@ import {BreadcrumbsModule} from "../../../openaireLibrary/utils/breadcrumbs/brea ] }) -export class InviteBasicModule { } +export class InviteBasicModule { + constructor(private iconsService: IconsService) { + this.iconsService.registerIcons([send, cog]) + } +} diff --git a/src/app/utils/subscribe/subscribe.component.ts b/src/app/utils/subscribe/subscribe.component.ts index c4aaba6..4dfbb47 100644 --- a/src/app/utils/subscribe/subscribe.component.ts +++ b/src/app/utils/subscribe/subscribe.component.ts @@ -26,10 +26,10 @@ declare var UIkit: any;

Please login first to subscribe

- - -