2019-06-05 15:39:02 +02:00
import { Component } from '@angular/core' ;
2019-08-28 14:54:35 +02:00
import { ActivatedRoute , NavigationStart , Router } from '@angular/router' ;
2018-02-12 12:41:40 +01:00
2019-06-05 15:39:02 +02:00
import { EnvProperties } from './openaireLibrary/utils/properties/env-properties' ;
import { MenuItem , RootMenuItem } from './openaireLibrary/sharedComponents/menu' ;
import { EnvironmentSpecificService } from './openaireLibrary/utils/properties/environment-specific.service' ;
2018-03-16 09:55:38 +01:00
import { CommunitiesService } from "./openaireLibrary/connect/communities/communities.service" ;
2019-09-13 09:47:29 +02:00
import { Session , User } from './openaireLibrary/login/utils/helper.class' ;
2018-03-29 10:28:04 +02:00
import { ConnectHelper } from './openaireLibrary/connect/connectHelper' ;
2019-04-12 13:05:28 +02:00
import { SubscribeService } from './openaireLibrary/utils/subscribe/subscribe.service' ;
2019-06-20 10:13:31 +02:00
import { HelperFunctions } from "./openaireLibrary/utils/HelperFunctions.class" ;
2019-09-13 09:47:29 +02:00
import { UserManagementService } from "./openaireLibrary/services/user-management.service" ;
2019-04-12 13:05:28 +02:00
2018-01-26 16:00:07 +01:00
@Component ( {
//changeDetection: ChangeDetectionStrategy.Default,
//encapsulation: ViewEncapsulation.Emulated,
selector : 'app-root' ,
styles : [ `
` ],
template : `
2019-08-28 14:54:35 +02:00
< div [ class ] = " ( community ) ? ( community.id + ' App ' ) : ' connectApp ' " >
2019-10-16 13:01:14 +02:00
< navbar * ngIf = "properties && showMenu && !community && loginCheck" [ portal ] = " properties.dashboard " [ onlyTop ] = false
2019-09-13 09:47:29 +02:00
[ userMenuItems ] = userMenuItems [ menuItems ] = menuItems [ user ] = "user"
2019-08-28 14:54:35 +02:00
[ showMenu ] = showMenu [ properties ] = "properties" [ showHomeMenuItem ] = "true" > < / navbar >
2019-11-08 12:04:10 +01:00
< navbar * ngIf = "properties && showMenu && community && loginCheck" [ portal ] = " properties.dashboard " [ onlyTop ] = false
[ communityId ] = "community.id"
2019-09-13 09:47:29 +02:00
[ userMenuItems ] = userMenuItems [ menuItems ] = menuItems [ user ] = "user"
2019-08-28 14:54:35 +02:00
[ community ] = community [ showMenu ] = showMenu [ properties ] = "properties" [ enableSearch ] = "true"
[ showHomeMenuItem ] = "true" > < / navbar >
2019-11-08 12:04:10 +01:00
< customization * ngIf = "properties && community" [ properties ] = " properties "
[ communityId ] = "community.id" > < / customization >
2019-08-28 14:54:35 +02:00
< div class = "custom-main-content" >
< main >
< router - outlet > < / r o u t e r - o u t l e t >
< / main >
2019-07-15 14:21:18 +02:00
< / div >
2019-08-28 14:54:35 +02:00
<!-- feedback * ngIf = "isClient && properties" portalName = "Connect" [ feedbackQuestionaire ] = properties . feedbackQuestionaire > < / f e e d b a c k - - >
< cookie - law * ngIf = "isClient" position = "bottom" >
OpenAIRE uses cookies in order to function properly . < br >
Cookies are small pieces of data that websites store in your browser to allow us to give you the best browsing
experience possible .
By using the OpenAIRE portal you accept our use of cookies . < a
href = "//ec.europa.eu/ipg/basics/legal/cookies/index_en.htm" target = "_blank" > Read more < span class = "uk-icon" >
< svg width = "20" height = "20" viewBox = "0 0 20 20" xmlns = "http://www.w3.org/2000/svg" icon = "chevron-right"
ratio = "1" > < polyline fill = "none" stroke = "#000" stroke - width = "1.03"
points = "7 4 13 10 7 16" > < / polyline > < / svg >
< / span > < / a >
< / c o o k i e - l a w >
< bottom * ngIf = "properties && isClient && showMenu && !community" [ grantAdvance ] = " false "
[ properties ] = "properties" > < / bottom >
< bottom * ngIf = "properties && isClient && showMenu && community" class = "communityPanelBackground"
[ showSocialButtons ] = "true" [ showMenuItems ] = "true" [ grantAdvance ] = "false" [ showOpenaire ] = "true"
[ communityId ] = "community.id" [ menuItems ] = bottomMenuItems [ properties ] = "properties" > < / bottom >
< / div >
`
2018-01-26 16:00:07 +01:00
} )
export class AppComponent {
2019-08-28 14:54:35 +02:00
isClient : boolean = false ;
2018-01-26 16:00:07 +01:00
2019-08-28 14:54:35 +02:00
userMenuItems : MenuItem [ ] = [ ] ;
2018-02-12 12:41:40 +01:00
2019-08-28 14:54:35 +02:00
menuItems : RootMenuItem [ ] = [ ] ;
bottomMenuItems : MenuItem [ ] = [ ] ;
2018-03-01 12:45:37 +01:00
public community = null ;
2019-08-28 14:54:35 +02:00
properties : EnvProperties ;
showMenu : boolean = false ;
2018-03-22 17:01:06 +01:00
communities = null ;
2019-04-16 16:26:09 +02:00
subscriberOfCommunities = false ;
managerOfCommunities = false ;
2019-09-13 09:47:29 +02:00
user : User ;
loginCheck : boolean = false ;
2018-02-12 12:41:40 +01:00
2019-08-28 14:54:35 +02:00
// community: {id:string, name:string, logoUrl:string};
constructor ( private route : ActivatedRoute , private propertiesService : EnvironmentSpecificService ,
private _communitiesService : CommunitiesService , private _subscribeService : SubscribeService ,
2019-09-13 09:47:29 +02:00
private router : Router , private userManagementService : UserManagementService ) {
2019-08-28 14:54:35 +02:00
router . events . forEach ( ( event ) = > {
if ( event instanceof NavigationStart ) {
HelperFunctions . scroll ( ) ;
}
} ) ;
}
2019-04-16 16:26:09 +02:00
2019-08-28 14:54:35 +02:00
ngOnInit() {
this . propertiesService . loadEnvironment ( )
. then ( es = > {
this . properties = this . propertiesService . envSpecific ;
this . _communitiesService . updateCommunities ( this . properties , this . properties . communitiesAPI ) ;
2019-11-08 12:04:10 +01:00
if ( typeof document !== 'undefined' ) {
try {
this . isClient = true ;
} catch ( e ) {
2019-08-28 14:54:35 +02:00
}
2019-11-08 12:04:10 +01:00
}
if ( this . isClient ) {
this . userManagementService . getUserInfo ( this . properties . userInfoUrl ) . subscribe ( user = > {
this . user = user ;
this . init ( ) ;
} ) ;
} else {
this . user = null ;
this . init ( ) ;
}
} , error = > {
console . log ( "App couldn't fetch properties" ) ;
console . log ( error ) ;
} ) ;
}
2018-02-12 12:41:40 +01:00
2019-11-08 12:04:10 +01:00
private init() {
let communityId : string = "" ;
this . loginCheck = true ;
if ( this . properties . environment == "development" ) {
this . showMenu = false ;
this . route . queryParams . subscribe ( params = > {
communityId = ( params [ 'communityId' ] ) ? params [ 'communityId' ] : '' ;
this . buildMenu ( communityId ) ;
} )
} else {
this . showMenu = false ;
communityId = ConnectHelper . getCommunityFromDomain ( this . properties . domain ) ;
this . buildMenu ( communityId ) ;
}
2019-08-28 14:54:35 +02:00
}
2019-04-17 16:48:06 +02:00
2019-08-28 14:54:35 +02:00
public buildMenu ( communityId : string ) {
let community = null ;
this . community = null ;
this . _communitiesService . getCommunitiesState ( ) . subscribe (
communities = > {
if ( ! communities || communities . length == 0 && communityId !== null && communityId !== '' ) {
return ;
}
for ( var com of communities ) {
if ( ( communityId && communityId != "" && com . communityId == communityId
&& community != null ) ||
(
! ( communityId && communityId != "" && com . communityId == communityId )
&&
this . managerOfCommunities && this . subscriberOfCommunities ) ) {
break ;
}
2019-09-13 09:47:29 +02:00
if ( this . user && com [ 'status' ] != "hidden" ) {
if ( Session . isCommunityCurator ( this . user ) || Session . isPortalAdministrator ( this . user ) ) {
2019-08-28 14:54:35 +02:00
this . managerOfCommunities = true ;
2019-09-13 09:47:29 +02:00
} else if ( com . managers . indexOf ( this . user . email ) != - 1 ) {
2019-08-28 14:54:35 +02:00
this . managerOfCommunities = true ;
}
}
2019-04-17 16:48:06 +02:00
2019-08-28 14:54:35 +02:00
if ( communityId && communityId != "" && com . communityId == communityId ) {
community = com ;
let isCommunityManager : boolean = false ;
2019-09-13 09:47:29 +02:00
if ( Session . isCommunityCurator ( this . user ) || Session . isPortalAdministrator ( this . user ) ) {
2019-08-28 14:54:35 +02:00
isCommunityManager = true ;
2019-09-16 11:33:23 +02:00
} else if ( this . user && com . managers . indexOf ( this . user . email ) != - 1 ) {
2019-08-28 14:54:35 +02:00
isCommunityManager = true ;
}
this . community = {
id : community.communityId ,
name : ( community . shortTitle ) ? community.shortTitle : community.title ,
logoUrl : community.logoUrl
} ;
this . menuItems = [ ] ;
2019-06-25 16:27:27 +02:00
2019-08-28 14:54:35 +02:00
this . menuItems . push (
{
rootItem : new MenuItem ( "search" , "Search" , "" , "/search/find" , false , [ ] , [ "/search/find" , "/search/find/publications" , "/search/find/datasets" , "/search/find/software" , "/search/find/other" , "/search/find/projects" , "/search/find/dataproviders" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
items : [ new MenuItem ( "" , "Publications" , "" , "/search/find/publications" , false , [ "publication" ] , [ "/search/find/publications" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
new MenuItem ( "" , "Research Data" , "" , "/search/find/datasets" , false , [ "dataset" ] , [ "/search/find/datasets" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
new MenuItem ( "" , "Software" , "" , "/search/find/software" , false , [ "software" ] , [ "/search/find/software" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
new MenuItem ( "" , "Other Research Products" , "" , "/search/find/other" , false , [ "orp" ] , [ "/search/find/other" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
new MenuItem ( "" , "Projects" , "" , "/search/find/projects/" , false , [ "project" ] , [ "/search/find/projects" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
new MenuItem ( "" , "Content Providers" , "" , "/search/find/dataproviders" , false , [ "datasource" ] , [ "/search/find/dataproviders" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
]
} ) ;
2019-06-20 15:34:07 +02:00
2019-08-28 14:54:35 +02:00
this . menuItems . push ( {
rootItem : new MenuItem ( "deposit" , "Deposit" , "" , "/participate/deposit/learn-how" , false , [ ] , [ "/participate/deposit/learn-how" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
2019-11-08 12:04:10 +01:00
items : [ ]
2019-08-28 14:54:35 +02:00
} ) ;
this . menuItems . push (
{
rootItem : new MenuItem ( "link" , "Link" , "" , "/participate/claim" , false , [ ] , [ "/participate/claim" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
items : [
new MenuItem ( "" , "Start linking" , "" , "/participate/claim" , false , [ ] , [ "/participate/claim" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
new MenuItem ( "" , "Learn more" , this . properties . claimsInformationLink , "" , false , [ ] , [ ] , { } )
]
} ) ;
if ( isCommunityManager ) {
this . menuItems . push (
{
rootItem : new MenuItem ( "manage" , "Manage" , 'https://beta.admin.connect.openaire.eu/dashboard?communityId=' + community . communityId , "" , false , [ ] , [ ] , { } ) ,
items : [ ]
} ) ;
}
2019-06-20 15:34:07 +02:00
2019-08-28 14:54:35 +02:00
}
2019-04-17 16:48:06 +02:00
2019-08-28 14:54:35 +02:00
}
if ( community == null ) {
this . menuItems = [ ] ;
this . menuItems . push ( {
rootItem : new MenuItem ( "about" , "About" , "" , "/about/learn-how" , false , [ ] , null , { } ) ,
items : [ ]
} ) ;
this . menuItems . push ( {
rootItem : new MenuItem ( "communities" , "Communities" , "" , "/search/find/communities" , false , [ ] , null , { } ) ,
items : [ ]
} ) ;
this . menuItems . push ( {
rootItem : new MenuItem ( "join" , "Join" , "" , "/contact-us" , false , [ ] , null , { } ) ,
items : [ ]
} ) ;
this . bottomMenuItems = [
new MenuItem ( "" , "About" , "https://beta.openaire.eu/project-factsheets" , "" , false , [ ] , [ ] , { } ) ,
new MenuItem ( "" , "News - Events" , "https://beta.openaire.eu/news-events" , "" , false , [ ] , [ ] , { } ) ,
new MenuItem ( "" , "Blog" , "https://blogs.openaire.eu/" , "" , false , [ ] , [ ] , { } ) ,
new MenuItem ( "" , "Contact us" , "https://beta.openaire.eu/contact-us" , "" , false , [ ] , [ ] , { } )
] ;
2019-11-08 12:04:10 +01:00
this . userMenuItems = [ ] ;
2019-09-13 09:47:29 +02:00
if ( Session . isPortalAdministrator ( this . user ) ) {
2019-08-28 14:54:35 +02:00
this . userMenuItems . push ( new MenuItem ( "" , "Manage Helptexts" ,
( ( this . properties . environment == "production" ) ? "https://admin.explore.openaire.eu" : "https://beta.admin.connect.openaire.eu" ) + "/dashboard?communityId=connect" ,
"" , false , [ ] , [ ] , { } ) )
}
2019-09-13 09:47:29 +02:00
if ( this . user ) {
2019-08-28 14:54:35 +02:00
this . userMenuItems . push ( new MenuItem ( "my-communities" , "My Communities" , "" ,
"/myCommunities" , false , [ ] , [ ] , { } ) ) ;
}
} else {
this . bottomMenuItems = [
new MenuItem ( "" , "Organizations" , "" , "/organizations" , false , [ ] , [ "/organizations" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } )
] ;
if ( this . properties . showContent ) {
this . bottomMenuItems . push ( new MenuItem ( "" , "Content Policy" , "" , "/content" , false , [ ] , [ ] , { } ) ) ;
}
this . userMenuItems = [ /*new MenuItem("","My profile","","",false,[],[],{}),*/
new MenuItem ( "" , "My links" , "" , "/myclaims" , false , [ ] , [ "/myclaims" ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
new MenuItem ( "" , "Invite users" , "" , "/invite" , false , [ ] , [ ] , this . properties . environment != "development" ? { } : { communityId : community.communityId } ) ,
] ;
if ( this . managerOfCommunities ) {
this . userMenuItems . push ( new MenuItem ( "" , "Support" , "https://openaire-connect.d4science.org/group/openaire-connect-gateway/explore?siteId=172366611" , "" , false , [ ] , [ ] , { } ) )
}
}
this . showMenu = true ;
} ) ;
}
2018-01-26 16:00:07 +01:00
}