2023-02-22 13:43:31 +01:00
import { Component , Input , OnInit , ViewChild } from "@angular/core" ;
2023-02-20 15:59:07 +01:00
import { StringUtils } from "../string-utils.class" ;
import { RouterHelper } from "../routerHelper.class" ;
import { properties } from "../../../../environments/environment" ;
2023-02-22 13:43:31 +01:00
import { Router } from "@angular/router" ;
import { Option } from "../../sharedComponents/input/input.component" ;
import { OpenaireEntities } from "../properties/searchFields" ;
import { EnvProperties } from "../properties/env-properties" ;
2023-02-20 15:59:07 +01:00
@Component ( {
selector : 'entity-actions' ,
template : `
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
< div class = "" [ ngClass ] = " isMobile ? ' uk - flex uk - flex - column ' : ' uk - grid uk - grid - small uk - flex - middle uk - child - width - auto ' " [ attr.uk - grid ] = " ! isMobile ? ' ' : null " >
2023-04-21 11:49:14 +02:00
< div * ngIf = "linking && isRouteAvailable('participate/direct-claim')" >
< a [ queryParams ] = " routerHelper.createQueryParams ( [ ' id ' , ' type ' , ' linkTo ' ] , [ id , type , linkTo ] ) "
2023-06-07 10:09:43 +02:00
routerLinkActive = "router-link-active" routerLink = "/participate/direct-claim"
2024-02-29 10:33:17 +01:00
[ attr . uk - tooltip ] = "showTooltip ? 'title: Link '+openaireEntities.RESULTS+' with a '+openaireEntities.PROJECT+', a '+openaireEntities.COMMUNITY+' or other '+openaireEntities.RESULTS+' and make the new information available in OpenAIRE information space.; pos: bottom; cls: uk-active uk-text-small uk-padding-small uk-width-medium' : 'cls: uk-invisible'"
2023-10-11 11:46:10 +02:00
class = "uk-flex uk-flex-middle uk-button-link" [ ngClass ] = "isMobile ? 'uk-margin-left uk-margin-xsmall-bottom' : 'uk-text-bolder uk-flex-center'" >
2023-04-21 11:49:14 +02:00
< icon [ flex ] = " true " [ ratio ] = " 0.7 " name = "link_to" visuallyHidden = "link" > < / icon >
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
< span * ngIf = "!compactView" class = "uk-margin-xsmall-left" > Link to < / span >
2023-04-21 11:49:14 +02:00
< / a >
< / div >
< div * ngIf = "share" >
< a ( click ) = " openAddThisModal ( ) "
2024-02-29 10:33:17 +01:00
[ attr . uk - tooltip ] = "showTooltip ? 'title: Share this '+getTypeName()+' in your social networks; pos: bottom; cls: uk-active uk-text-small uk-padding-small' : 'cls: uk-invisible'"
2023-10-11 11:46:10 +02:00
class = "uk-flex uk-flex-middle uk-button-link" [ ngClass ] = "isMobile ? 'uk-margin-left uk-margin-xsmall-bottom' : 'uk-text-bolder uk-flex-center'" >
< icon class = "uk-text-bolder" [ flex ] = " true " [ ratio ] = " 0.8 " name = "share" visuallyHidden = "share" > < / icon >
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
< span * ngIf = "!compactView" class = "uk-margin-xsmall-left" > Share < / span >
2023-04-21 11:49:14 +02:00
< / a >
< / div >
< div * ngIf = "cite" >
< a ( click ) = " openCiteModal ( ) "
2023-10-11 11:46:10 +02:00
class = "uk-flex uk-flex-middle uk-button-link" [ ngClass ] = "isMobile ? 'uk-margin-left uk-margin-xsmall-bottom' : 'uk-text-bolder uk-flex-center'" >
< icon class = "uk-text-bolder" [ flex ] = " true " [ ratio ] = " 0.7 " name = "cite" visuallyHidden = "cite" > < / icon >
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
< span * ngIf = "!compactView" class = "uk-margin-xsmall-left" > Cite < / span >
2023-04-21 11:49:14 +02:00
< / a >
< / div >
< div * ngIf = "deposit && isRouteAvailable('participate/deposit/learn-how')" >
< a routerLinkActive = "router-link-active" routerLink = "/participate/deposit/learn-how"
2024-02-29 10:33:17 +01:00
[ attr . uk - tooltip ] = "showTooltip ? 'title: Find a repository to deposit or publish your research in Open Access; pos: bottom; cls: uk-active uk-text-small uk-padding-small uk-width-medium' : 'cls: uk-invisible'"
2023-10-11 11:46:10 +02:00
class = "uk-flex uk-flex-middle uk-button-link" [ ngClass ] = "isMobile ? 'uk-margin-left uk-margin-xsmall-bottom' : 'uk-text-bolder uk-flex-center'" >
2023-04-21 11:49:14 +02:00
< icon flex = "true" ratio = "0.7" name = "upload" visuallyHidden = "upload" > < / icon >
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
< span * ngIf = "!compactView" class = "uk-margin-xsmall-left" > Deposit < / span >
2023-04-21 11:49:14 +02:00
< / a >
< / div >
2024-12-02 14:27:41 +01:00
< div * ngIf = "embed && properties.environment !== 'beta'" >
2023-04-21 11:49:14 +02:00
< a ( click ) = " openEmbedResultsModal ( ) "
2024-02-29 10:33:17 +01:00
[ attr . uk - tooltip ] = "showTooltip ? 'title: Embed the related '+openaireEntities.RESULTS+' of this '+getTypeName()+' in your website; pos: bottom; cls: uk-active uk-text-small uk-padding-small uk-width-medium' : 'cls: uk-invisible'"
2023-10-11 11:46:10 +02:00
class = "uk-flex uk-flex-middle uk-button-link" [ ngClass ] = "isMobile ? 'uk-margin-left uk-margin-xsmall-bottom' : 'uk-text-bolder uk-flex-center'" >
2023-04-21 11:49:14 +02:00
< icon flex = "true" ratio = "0.8" name = "code" visuallyHidden = "code" > < / icon >
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
< span * ngIf = "!compactView" class = "uk-margin-xsmall-left" > Embed < / span >
2023-04-21 11:49:14 +02:00
< / a >
< / div >
2023-02-20 15:59:07 +01:00
< ng - content > < / n g - c o n t e n t >
< / div >
< modal - alert * ngIf = "cite" # citeModal >
< citeThis * ngIf = "citeThisClicked" [ result ] = " result " [ id ] = " id "
2023-07-12 14:05:25 +02:00
[ type ] = "getTypeName().toLowerCase()" > < / citeThis >
2023-02-20 15:59:07 +01:00
< / m o d a l - a l e r t >
< modal - alert * ngIf = "share" # addThisModal classBody = "uk-flex uk-flex-center uk-flex-middle" >
2024-07-18 14:48:20 +02:00
< addThis * ngIf = "addThisClicked" [ url ] = " url " > < / addThis >
2023-02-20 15:59:07 +01:00
< / m o d a l - a l e r t >
2023-02-22 13:43:31 +01:00
< modal - alert * ngIf = "result" # embedResultsModal large = "true" >
< div class = "uk-padding-small uk-margin-small-left uk-margin-small-right" >
< div class = "uk-padding-small uk-padding-remove-vertical" >
< div input type = "select" placeholder = "Select content type to embed" inputClass = "flat x-small"
2023-06-07 10:09:43 +02:00
[ options ] = "resultTypesForEmbedding" [ ( value ) ] = "embed_research_results_type" > < / div >
2023-02-22 13:43:31 +01:00
< div * ngIf = "embed_research_results_type" class = "clipboard-wrapper box-content uk-grid uk-margin-auto uk-margin-small-top " >
< pre id = "dynamic_content_id" class = "uk-overflow-auto uk-padding-small uk-padding-remove-vertical uk-margin-top" > < code
> { { getDynamicContent ( embed_research_results_type ) } } < / code > < / pre >
< div class = "uk-width-1-1 uk-padding-small uk-text-right" >
< a class = "uk-link copy clipboard_btn" data - clipboard - target = "#dynamic_content_id" title = "Copy script" >
COPY SCRIPT
< / a >
< / div >
< / div >
< div class = "uk-text-small uk-margin-top" >
For further information contact us at
< u > < a [ href ] = " ' mailto : ' + properties.helpdeskEmail " class = "uk-link-text" > { { properties . helpdeskEmail } } < / a > < / u >
< / div >
< / div >
< / div >
< / m o d a l - a l e r t >
2023-02-20 15:59:07 +01:00
`
} )
2023-02-22 13:43:31 +01:00
export class EntityActionsComponent implements OnInit {
2023-02-20 15:59:07 +01:00
@Input ( ) result : any ;
@Input ( ) type : string ;
@Input ( ) id : string ;
@Input ( ) linking : boolean = false ;
@Input ( ) share : boolean = false ;
@Input ( ) cite : boolean = false ;
2023-02-22 13:43:31 +01:00
@Input ( ) deposit : boolean = false ;
@Input ( ) embed : boolean = false ;
2023-02-20 15:59:07 +01:00
@Input ( ) url : string ;
2023-06-07 10:09:43 +02:00
@Input ( ) isMobile : boolean = false ;
2024-02-29 10:33:17 +01:00
@Input ( ) showTooltip : boolean = true ;
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
@Input ( ) compactView : boolean = false ; // if true, do not show label for actions
2023-02-20 15:59:07 +01:00
public citeThisClicked : boolean ;
2024-07-18 14:48:20 +02:00
public addThisClicked : boolean ;
2023-02-20 15:59:07 +01:00
public routerHelper : RouterHelper = new RouterHelper ( ) ;
@ViewChild ( 'citeModal' ) citeModal ;
2023-02-22 13:43:31 +01:00
@ViewChild ( 'embedResultsModal' ) embedResultsModal ;
2023-02-20 15:59:07 +01:00
@ViewChild ( 'addThisModal' ) addThisModal ;
2023-02-22 13:43:31 +01:00
properties : EnvProperties = properties ;
2023-02-23 12:09:42 +01:00
openaireEntities = OpenaireEntities ;
[develop | DONE | ADDED]: Added compact view functionality on search pages.
1. newSearchPage.component.html: Increase left margin of download button | Added button for compact view | In <search-result> added parameter "compactView".
2. newSearchPage.component.html: Added class fields "@Input() hasCompactView: boolean = false;", to show compact button or not and "public compactView: boolean = false;" to show compact or expanded view of each result.
3. searchDownload.component.ts: Changed download <button> to <a> with class "custom-view-button" | Set visuallyHidden to icon.
4. searchResult.component.ts: Added class field "@Input() compactView: boolean = false;".
5. searchResult.component.html: In <result-preview added parameter "compactView".
6. entity-actions.component.ts: Added class field "@Input() compactView: boolean = false;" | When compactView is true, hide action labels - show only icons.
7. result-preview.component.ts: Added class field "@Input() compactView: boolean = false;".
8. result-preview.component.html: When compactView is true, make margins smaller, show 1 line in title, hide funder budget, identifiers, website url, oai-pmh url, description, action oa routes and metrics labels, and added "compactView" parameter in <entity-actions>.
2024-07-09 16:11:55 +02:00
2023-02-22 13:43:31 +01:00
/* Embed */
public embed_research_results_type : string = "result" ;
public clipboard ;
public resultTypesForEmbedding : Option [ ] = [
{ label : "All " + OpenaireEntities . RESULTS , value : "result" } ,
{ label : OpenaireEntities.PUBLICATIONS , value : "publication" } ,
{ label : OpenaireEntities.DATASETS , value : "dataset" } ,
{ label : OpenaireEntities.SOFTWARE , value : "software" } ,
{ label : OpenaireEntities.OTHER , value : "other" } ] ;
constructor ( private router : Router ) {
2023-02-20 15:59:07 +01:00
}
2023-02-22 13:43:31 +01:00
ngOnInit() {
this . createClipboard ( ) ;
}
2023-02-20 15:59:07 +01:00
get linkTo ( ) : string {
return this . type === 'project' ? 'result' : 'project' ;
}
public getTypeName ( ) : string {
return StringUtils . getEntityName ( this . type , false ) ;
}
public openCiteModal() {
this . citeThisClicked = true ;
this . citeModal . cancelButton = false ;
this . citeModal . okButton = false ;
this . citeModal . alertTitle = "Cite this " + this . getTypeName ( ) ;
this . citeModal . open ( ) ;
}
public openAddThisModal() {
2024-07-18 14:48:20 +02:00
this . addThisClicked = true ;
2023-02-20 15:59:07 +01:00
this . addThisModal . cancelButton = false ;
this . addThisModal . okButton = false ;
this . addThisModal . alertTitle = "Share this " + this . getTypeName ( ) + " in your social networks" ;
this . addThisModal . open ( ) ;
}
2023-02-22 13:43:31 +01:00
public openEmbedResultsModal() {
this . embedResultsModal . cancelButton = false ;
this . embedResultsModal . okButton = false ;
this . embedResultsModal . alertTitle = "Embed results" ;
this . embedResultsModal . open ( ) ;
}
private createClipboard() {
if ( typeof window !== 'undefined' ) {
delete this . clipboard ;
let Clipboard ;
Clipboard = require ( 'clipboard' ) ;
this . clipboard = new Clipboard ( '.clipboard_btn' ) ;
}
}
getDynamicContent ( type : string ) {
return "<script type=\"text/javascript\">"
+ "\n<!--"
+ "\ndocument.write('<div id=\"oa_widget\"></div>');"
+ "\ndocument.write('<script type=\"text/javascript\""
+ " src=\"" + this . properties . widgetLink
+ this . result . id + "&type="
+ type
+ "\"></script>');"
+ "\n-->"
+ "\n</script>" ;
}
isRouteAvailable ( routeToCheck : string ) {
for ( let i = 0 ; i < this . router . config . length ; i ++ ) {
let routePath : string = this . router . config [ i ] . path ;
2023-12-19 10:52:27 +01:00
if ( routePath == routeToCheck || routeToCheck . split ( '/' ) [ 0 ] == routePath ) {
2023-02-22 13:43:31 +01:00
return true ;
}
}
return false ;
}
2023-02-20 15:59:07 +01:00
}