{"version":3,"sources":["./$_lazy_route_resource lazy namespace object","./src/app/app.component.html","./src/app/components/footer.component.html","./src/app/components/menu.component.html","./src/app/components/page-not-found.component.html","./src/app/e-auth/components/e-auth-profile-modal.component.html","./src/app/e-auth/components/e-auth-response.component.html","./src/app/e-auth/components/e-auth-send-request-modal.component.html","./src/classifications/components/organization-view/organization-view.component.html","./src/classifications/components/organization/organization.component.html","./src/classifications/components/scientific-area/scientific-area.component.html","./src/components/async-select/async-select.component.html","./src/components/collapsable-text/collapsable-text.component.html","./src/components/drawer/drawer.component.html","./src/components/foreign-name-selector/foreign-name-selector.component.html","./src/components/language-selector/language-selector.component.html","./src/components/link-or-text/link-or-text.component.html","./src/components/loading-indicator/loading-indicator.component.html","./src/components/loading-section/loading-section.component.html","./src/components/paginator/paginator.component.html","./src/components/select/select.component.html","./src/components/show-more/show-more.component.html","./src/publication/components/publication-details/publication-details.component.html","./src/publication/components/publication-view/publication-view.component.html","./src/search/components/events/events.component.html","./src/search/components/information/information-item/information-item.component.html","./src/search/components/information/information.component.html","./src/search/components/landing-page/landing-page.component.html","./src/search/components/news/news.component.html","./src/search/components/search-categories/search-categories.component.html","./src/search/components/search-filter/search-filter.component.html","./src/search/components/search-result/search-result.component.html","./src/search/components/search-sidebar/search-sidebar.component.html","./src/search/components/search/search.component.html","./src/shared/components/publication-identifier/publication-identifier.component.html","./src/shared/components/publication-subheading-bar/publication-subheading-bar.component.html","./src/app/app-routing.module.ts","./src/app/app.component.ts","./src/app/app.module.ts","./src/app/components/footer.component.scss","./src/app/components/footer.component.ts","./src/app/components/menu.component.scss","./src/app/components/menu.component.ts","./src/app/components/page-not-found.component.scss","./src/app/components/page-not-found.component.ts","./src/app/components/redirect-reward.component.ts","./src/app/e-auth/components/e-auth-profile-modal.component.ts","./src/app/e-auth/components/e-auth-response.component.ts","./src/app/e-auth/components/e-auth-send-request-modal.component.ts","./src/app/e-auth/e-auth.resource.ts","./src/app/e-auth/enums/e-auth-response-status.enum.ts","./src/app/e-auth/services/e-auth-user.service.ts","./src/classifications/classifications.module.ts","./src/classifications/classifications.routing.ts","./src/classifications/components/organization-view/organization-view.component.scss","./src/classifications/components/organization-view/organization-view.component.ts","./src/classifications/components/organization/organization.component.scss","./src/classifications/components/organization/organization.component.ts","./src/classifications/components/scientific-area/scientific-area.component.scss","./src/classifications/components/scientific-area/scientific-area.component.ts","./src/classifications/services/organization-data-resolver.service.ts","./src/classifications/services/organization-view-data-resolver.service.ts","./src/classifications/services/scientific-area-data-resolver.service.ts","./src/classifications/styles/common.scss","./src/common.scss","./src/components/async-select/async-select.component.scss","./src/components/async-select/async-select.component.ts","./src/components/async-select/models/base-filter.ts","./src/components/collapsable-text/collapsable-text.component.scss","./src/components/collapsable-text/collapsable-text.component.ts","./src/components/components.module.ts","./src/components/drawer/drawer.component.scss","./src/components/drawer/drawer.component.ts","./src/components/foreign-name-selector/foreign-name-selector.component.ts","./src/components/icons/globe.icon.ts","./src/components/icons/lightbulb.icon.ts","./src/components/language-selector/language-selector.component.scss","./src/components/language-selector/language-selector.component.ts","./src/components/link-or-text/link-or-text.component.scss","./src/components/link-or-text/link-or-text.component.ts","./src/components/loading-indicator/loading-indicator.component.scss","./src/components/loading-indicator/loading-indicator.component.ts","./src/components/loading-section/loading-section.component.ts","./src/components/paginator/paginator.component.scss","./src/components/paginator/paginator.component.ts","./src/components/select/select.component.scss","./src/components/select/select.component.ts","./src/components/show-more/show-more.component.scss","./src/components/show-more/show-more.component.ts","./src/environments/environment.ts","./src/infrastructure/base.resource.ts","./src/infrastructure/configuration/configuration.ts","./src/infrastructure/loading-indicator.service.ts","./src/infrastructure/locale.service.ts","./src/infrastructure/ng-bootstrap.module.ts","./src/infrastructure/utils.ts","./src/main.ts","./src/page-styles.scss","./src/pages/pages.module.ts","./src/publication/components/publication-details/publication-details.component.scss","./src/publication/components/publication-details/publication-details.component.ts","./src/publication/components/publication-view/publication-view.component.scss","./src/publication/components/publication-view/publication-view.component.ts","./src/publication/models/source-type.enum.ts","./src/publication/publication.module.ts","./src/publication/publication.routing.ts","./src/publication/services/publication-view-resolver.service.ts","./src/search/components/events/events.component.ts","./src/search/components/information/information-item/information-item.component.css","./src/search/components/information/information-item/information-item.component.ts","./src/search/components/information/information-type.enum.ts","./src/search/components/information/information.component.scss","./src/search/components/information/information.component.ts","./src/search/components/information/information.resource.ts","./src/search/components/landing-page/landing-page.component.scss","./src/search/components/landing-page/landing-page.component.ts","./src/search/components/news-common-styles.scss","./src/search/components/news/news.component.ts","./src/search/components/search-categories/search-categories.component.scss","./src/search/components/search-categories/search-categories.component.ts","./src/search/components/search-filter/search-filter.component.scss","./src/search/components/search-filter/search-filter.component.ts","./src/search/components/search-result/search-result.component.scss","./src/search/components/search-result/search-result.component.ts","./src/search/components/search-sidebar/search-sidebar.component.scss","./src/search/components/search-sidebar/search-sidebar.component.ts","./src/search/components/search/search.component.scss","./src/search/components/search/search.component.ts","./src/search/models/logical-operator.enum.ts","./src/search/models/search-field-mode.enum.ts","./src/search/models/search-field-type-spec.ts","./src/search/models/search-field-type.enum.ts","./src/search/models/search-field.ts","./src/search/models/search-mode.enum.ts","./src/search/search-routing.module.ts","./src/search/search.module.ts","./src/search/services/logical-operator-query-builder.service.ts","./src/search/services/search.resource.ts","./src/search/services/search.state.ts","./src/shared/components/publication-identifier/publication-identifier.component.scss","./src/shared/components/publication-identifier/publication-identifier.component.ts","./src/shared/components/publication-subheading-bar/publication-subheading-bar.component.scss","./src/shared/components/publication-subheading-bar/publication-subheading-bar.component.ts","./src/shared/shared.module.ts"],"names":[],"mappings":"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","file":"main.js","sourcesContent":["function webpackEmptyAsyncContext(req) {\n\t// Here Promise.resolve().then() is used instead of new Promise() to prevent\n\t// uncaught exception popping up in devtools\n\treturn Promise.resolve().then(function() {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t});\n}\nwebpackEmptyAsyncContext.keys = function() { return []; };\nwebpackEmptyAsyncContext.resolve = webpackEmptyAsyncContext;\nmodule.exports = webpackEmptyAsyncContext;\nwebpackEmptyAsyncContext.id = \"./$$_lazy_route_resource lazy recursive\";","module.exports = \"
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"
\\r\\n
\\r\\n 404\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n {{'notFound.text' | translate}}\\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n

\\r\\n {{ 'eAuth.modals.profile' | translate }}\\r\\n

\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n {{ eAuthUserService.userName }}\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\"","module.exports = \"

\\r\\n {{ errorMessage }}\\r\\n

\"","module.exports = \"
\\r\\n

\\r\\n {{ 'eAuth.modals.sendRequestHeader' | translate }}\\r\\n

\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n

\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n\\r\\n
\\r\\n

{{organization.name}}

\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n {{item.name}}\\r\\n ({{item.count | number:'':'bg-BG'}})\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n < {{ 'common.back' | translate }}\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n

{{ 'contentProviders.title' | translate}}

\\r\\n\\r\\n
\\r\\n

\\r\\n {{'contentProviders.p1' | translate}}\\r\\n

\\r\\n\\r\\n

\\r\\n {{'contentProviders.p2' | translate}}\\r\\n

\\r\\n
\\r\\n\\r\\n

\\r\\n {{'contentProviders.subtitle' | translate}}\\r\\n

\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n {{value}}\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n {{value}}\\r\\n \\r\\n \\r\\n\\r\\n ({{item.count | number:'':'bg-BG'}})\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\"","module.exports = \"
\\r\\n
\\r\\n\\r\\n
\\r\\n

{{ 'menu.scientificAreas' | translate }}

\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n {{mainArea.name}}\\r\\n \\r\\n ({{mainArea.count | number:'':'bg-BG'}})\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n {{area.name}}\\r\\n \\r\\n ({{area.count | number:'':'bg-BG'}})\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n {{ 'scientificArea.remark1' | translate}}
\\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n {{item.name}}\\r\\n\\r\\n\\r\\n\\r\\n {{value?.name || value?.alias || placeholder}}\\r\\n\"","module.exports = \"
\\r\\n
\\r\\n
\\r\\n {{text.slice(0, 300) }}\\r\\n 300\\\">...\\r\\n
\\r\\n\\r\\n
300\\\"\\r\\n class=\\\"link primary collapse-control\\\"\\r\\n (click)=\\\"isCollapsed = !isCollapsed\\\">\\r\\n {{ 'texts.showMore' | translate }}\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n {{text}}\\r\\n
300\\\"\\r\\n class=\\\"link primary collapse-control\\\"\\r\\n (click)=\\\"isCollapsed = !isCollapsed\\\">\\r\\n \\r\\n {{ 'texts.showLess' | translate }}\\r\\n
\\r\\n
\\r\\n
\"","module.exports = \"\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n\"","module.exports = \"\\r\\n {{value}}\\r\\n\\r\\n\\r\\n\"","module.exports = \"
\\r\\n \\r\\n \\r\\n \\r\\n {{selected?.name}}\\r\\n
\"","module.exports = \"{{textValue}}\\r\\n\\r\\n{{textValue}}\"","module.exports = \"\"","module.exports = \"
\\r\\n
\\r\\n {{ loadingText | translate }}\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n \\r\\n {{'paginator.page' | translate}} ({{this.page + 1}}/{{this.numberOfPages}}):\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n {{ 'paginator.firstPage' | translate}}\\r\\n ... \\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n {{pageOption + 1}}\\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n ... \\r\\n {{ 'paginator.lastPage' | translate }}\\r\\n
\\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n {{item}}\\r\\n\\r\\n\\r\\n {{value}}\\r\\n\"","module.exports = \"
\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
visibleItems\\\"\\r\\n [ngStyle]=\\\"{'margin-left.px': marginLeft}\\\"\\r\\n class=\\\"show-more-label-container\\\">\\r\\n \\r\\n {{ 'category.showMore' | translate}}\\r\\n \\r\\n \\r\\n <\\r\\n {{ 'category.showLess' | translate}}\\r\\n \\r\\n
\"","module.exports = \"
\\r\\n \\r\\n \\r\\n {{ 'publication.details' | translate }}\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.viewCount' | translate}}:\\r\\n \\r\\n
\\r\\n {{publication.viewCount}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.institution' | translate }}:\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n {{value || ('texts.noContent' | translate)}}\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.contributors' | translate }}:\\r\\n \\r\\n
\\r\\n {{contributors || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.publicationDate' | translate }}:\\r\\n \\r\\n
\\r\\n {{ (publication.publicationDate | date:'dd.MM.yyyy') || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.publicationYear' | translate }}:\\r\\n \\r\\n
\\r\\n {{ (publication.publicationYear ) || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.funding' | translate}}:\\r\\n \\r\\n
\\r\\n {{fundingReference || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.version' | translate}}:\\r\\n \\r\\n
\\r\\n {{publication.version + 1}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.relatedIdentifiers' | translate }}:\\r\\n \\r\\n
\\r\\n {{relatedIdentifiers || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.alternativeIdentifiers' | translate }}:\\r\\n \\r\\n
\\r\\n {{alternativeIdentifiers || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.sources' |translate }}:\\r\\n \\r\\n
\\r\\n {{sources || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.coverages' |translate }}:\\r\\n \\r\\n
\\r\\n {{coverages || ('texts.noContent' | translate)}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.citation' | translate }}:\\r\\n \\r\\n
\\r\\n \\r\\n {{publication.citation.title}},\\r\\n {{ 'publication.citation.volume' | translate}}\\r\\n {{publication.citation.volume}},\\r\\n {{ 'publication.citation.issue' | translate}}\\r\\n {{publication.citation.issue}},\\r\\n {{ 'publication.citation.pages' | translate }}\\r\\n {{publication.citation.startPage}} -\\r\\n {{publication.citation.endPage}}.\\r\\n \\r\\n \\r\\n {{'texts.noContent' | translate}}\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.audience' | translate }}:\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n {{value}}\\r\\n \\r\\n \\r\\n \\r\\n {{'texts.noContent' | translate}}\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.accessRight' | translate }}:\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n {{value}}\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.license' | translate }}:\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n {{value || ('texts.noContent' | translate)}}\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n < {{ 'common.back' | translate }}\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\\r\\n

\\r\\n {{publication.titles[0]}}\\r\\n

\\r\\n\\r\\n

\\r\\n {{publication.titles[1]}}\\r\\n

\\r\\n\\r\\n
\\r\\n {{title}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.creators' | translate}}:\\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\\"ORCID\\r\\n {{creator.name}}\\r\\n \\r\\n\\r\\n {{creator.name}}\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n {{subject}}\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n
\\r\\n

\\r\\n {{description}}\\r\\n

\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n {{ 'publication.sourceTypeText' | translate }}\\r\\n\\r\\n \\r\\n \\r\\n {{value}}.\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n {{'publication.files' | translate}}\\r\\n\\r\\n
\\r\\n \\r\\n {{file.name}}\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n {{file.url}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n\\r\\n
0\\\">\\r\\n
{{ 'publication.funding' | translate }}
\\r\\n\\r\\n
\\r\\n
\\r\\n {{funding.funderName}}\\r\\n
\\r\\n
\\r\\n \\\"{{funding.awardTitle}}\\\"\\r\\n
\\r\\n
\\r\\n ({{funding.awardNumber}})\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
{{ 'publication.publishers' | translate }}
\\r\\n\\r\\n
\\r\\n {{publisher}}\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
{{ 'publication.citation' | translate }}
\\r\\n
\\r\\n {{publication.citation.title}},\\r\\n {{ 'publication.citation.volume' | translate}}\\r\\n {{publication.citation.volume}},\\r\\n {{ 'publication.citation.issue' | translate}}\\r\\n {{publication.citation.issue}},\\r\\n {{ 'publication.citation.pages' | translate }}\\r\\n {{publication.citation.startPage}} -\\r\\n {{publication.citation.endPage}}.\\r\\n
\\r\\n
\\r\\n\\r\\n
1\\\">\\r\\n
{{ 'publication.languages' | translate }}
\\r\\n\\r\\n \\r\\n \\r\\n {{value}}\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
{{ 'publication.license' | translate}}
\\r\\n\\r\\n \\r\\n \\r\\n {{value}}\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n < {{ 'common.back' | translate }}\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n

\\r\\n {{ 'enums.informationType.events' | translate }}\\r\\n

\\r\\n\\r\\n

\\r\\n {{ 'events.subtitle' | translate }}\\r\\n

\\r\\n\\r\\n\\r\\n \\r\\n
{{item.title}}
\\r\\n
\\r\\n {{item.date | date:'d MMMM y':'':locale.locale}}\\r\\n
\\r\\n
\\r\\n

\\r\\n {{item.content}}\\r\\n

\\r\\n
\\r\\n\\r\\n

\\r\\n \\r\\n \\r\\n {{ file.description }}\\r\\n \\r\\n

\\r\\n\\r\\n

\\r\\n \\r\\n \\r\\n {{ 'events.' + (linkIndex == 0 ? 'primaryLink' : 'secondaryLink') | translate }}\\r\\n \\r\\n

\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\"","module.exports = \"
{{item.title}}
\\r\\n
\\r\\n {{item.date | date:'d MMMM y':'':locale.locale}}\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n

\\r\\n {{item.content}}\\r\\n

\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'news.showMore' | translate }}\\r\\n \\r\\n >\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n {{file.description}}\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n {{InformationType[section.type] + (linkIndex == 0 ? '.primaryLink' : '.secondaryLink') | translate }}\\r\\n \\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n {{ 'enums.informationType.' + InformationType[section.type] | translate }}\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n
\"","module.exports = \"\\r\\n\\r\\n\"","module.exports = \"
\\r\\n
\\r\\n < {{ 'common.back' | translate }}\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n

\\r\\n {{ 'news.title' | translate }}\\r\\n

\\r\\n\\r\\n

\\r\\n {{ 'news.subtitle' | translate }}\\r\\n

\\r\\n \\r\\n
{{item.title}}
\\r\\n
\\r\\n {{item.date | date:'d MMMM y':'':locale.locale}}\\r\\n
\\r\\n
\\r\\n

\\r\\n {{item.content}}\\r\\n

\\r\\n
\\r\\n\\r\\n

\\r\\n \\r\\n \\r\\n {{ file.description }}\\r\\n \\r\\n

\\r\\n\\r\\n

\\r\\n \\r\\n \\r\\n {{ 'news.' + (linkIndex == 0 ? 'primaryLink' : 'secondaryLink') | translate }}\\r\\n \\r\\n

\\r\\n\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n\\r\\n
\\r\\n
\\r\\n {{ 'enums.searchFieldType.' + SearchFieldType[category] | translate | uppercase}}\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n ({{item.count | number:'':'bg-BG'}})\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\"","module.exports = \"
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n

{{ 'search.title' | translate | uppercase }}

\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'search.advancedSearchLink' | translate }}\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n {{ 'search.quicksearchLink' | translate }}\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n

{{ 'search.advanced' | translate | uppercase }}

\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'search.advanced.fieldTypeLabel' | translate }}\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n {{'enums.logicalOperator.' + LogicalOperator[value] | translate }}\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n {{ 'enums.logicalOperator.' + LogicalOperator[item] | translate }}\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n {{'enums.searchFieldType.' + SearchFieldType[value] | translate }}\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n {{ 'enums.searchFieldType.' + SearchFieldType[item] | translate }}\\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n {{value || ( 'search.advanced.searchTerm.placeholder' | translate)}}\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n
\"","module.exports = \"
\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n {{ 'publication.creators' | translate}}:\\r\\n \\r\\n\\r\\n {{creator}}\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n {{subject}}\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\"","module.exports = \"
\\r\\n\\r\\n\\r\\n
\\r\\n
{{ 'search.sidebar.filters' | translate }}
\\r\\n\\r\\n\\r\\n
0\\\">\\r\\n \\r\\n \\r\\n {{ 'search.sidebar.clear' | translate }}\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n
{{ 'enums.searchFieldType.' + SearchFieldType[category] | translate}}
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\"","module.exports = \"\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
0 && totalCount < 10000\\\">\\r\\n {{'search.found' | translate}}:\\r\\n {{totalCount | number:'':'bg-BG'}}\\r\\n
\\r\\n\\r\\n
\\r\\n {{'search.foundMoreThan' | translate}}\\r\\n {{ 9990 | number:'':'bg-BG'}}\\r\\n
\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n 0\\\"\\r\\n [searchFields]=\\\"searchFields\\\"\\r\\n [categories]=\\\"categories\\\">\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n {{ 'search.noResultsFound' | translate}}\\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n
\"","module.exports = \"
{{'publication.identifier' | translate}}:
\\r\\n\\r\\n
\\r\\n {{identifier.type}}:\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n \\r\\n
\"","module.exports = \"
\\r\\n \\r\\n {{model.publicationDate | date:'d MMMM y':'':locale.locale}},\\r\\n \\r\\n\\r\\n \\r\\n {{model.publicationYear}},\\r\\n \\r\\n\\r\\n \\r\\n \\r\\n {{value}},\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n {{value}}\\r\\n \\r\\n\\r\\n \\r\\n \\r\\n
\"","import { NgModule } from \"@angular/core\";\r\nimport { RouterModule, Routes } from \"@angular/router\";\r\nimport { PageNotFoundComponent } from \"./components/page-not-found.component\";\r\nimport { RedirectRewardComponent } from \"./components/redirect-reward.component\";\r\nimport { EAuthResponseComponent } from \"./e-auth/components/e-auth-response.component\";\r\n\r\nconst routes: Routes = [\r\n {\r\n path: \"reward\",\r\n component: RedirectRewardComponent\r\n },\r\n {\r\n path: \"eAuthResponse\",\r\n component: EAuthResponseComponent\r\n },\r\n {\r\n path: \"**\",\r\n component: PageNotFoundComponent,\r\n data: {\r\n title: \"pages.notFound\"\r\n }\r\n }\r\n];\r\n\r\n@NgModule({\r\n imports: [RouterModule.forRoot(routes)],\r\n exports: [RouterModule]\r\n})\r\nexport class AppRoutingModule { }\r\n","import { Component, AfterViewInit } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { LoadingIndicatorService } from 'src/infrastructure/loading-indicator.service';\r\nimport { Router, ActivatedRoute } from '@angular/router';\r\nimport { Title } from '@angular/platform-browser';\r\nimport { getPageTitle, getPageLanguage, getNavigationForGtag, gtagConfigEvent, initLocalization } from 'src/infrastructure/utils';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\n\r\ndeclare let gtag: Function;\r\n\r\n@Component({\r\n selector: 'app-root',\r\n templateUrl: 'app.component.html',\r\n styles: []\r\n})\r\nexport class AppComponent implements AfterViewInit {\r\n constructor(\r\n private router: Router,\r\n private activatedRoute: ActivatedRoute,\r\n private translate: TranslateService,\r\n private loadingIndicator: LoadingIndicatorService,\r\n private titleService: Title,\r\n private localeService: LocaleService,\r\n private config: Configuration\r\n ) {\r\n initLocalization(this.activatedRoute, this.translate, this.localeService);\r\n }\r\n\r\n isLoading: boolean = false;\r\n\r\n ngAfterViewInit() {\r\n this.loadingIndicator.change$.subscribe((isLoading: boolean) => {\r\n setTimeout(() => this.isLoading = isLoading, 100);\r\n });\r\n\r\n getPageTitle(this.router, this.activatedRoute, this.translate)\r\n .subscribe(title => this.titleService.setTitle(title));\r\n\r\n getPageLanguage(this.router)\r\n .subscribe(lang => this.translate.use(lang));\r\n\r\n if (this.config.enableAnalytics) {\r\n gtag('config', this.config.analyticsTrackingId);\r\n getNavigationForGtag(this.router)\r\n .subscribe(url => gtagConfigEvent(url, this.config.analyticsTrackingId));\r\n }\r\n }\r\n}\r\n","import { CommonModule } from \"@angular/common\";\r\nimport { HttpClient, HttpClientModule } from \"@angular/common/http\";\r\nimport { APP_INITIALIZER, LOCALE_ID, NgModule } from \"@angular/core\";\r\nimport { BrowserModule } from \"@angular/platform-browser\";\r\nimport { FontAwesomeModule } from \"@fortawesome/angular-fontawesome\";\r\nimport { TranslateLoader, TranslateModule } from \"@ngx-translate/core\";\r\nimport { TranslateHttpLoader } from \"@ngx-translate/http-loader\";\r\nimport { ClassificationsModule } from \"src/classifications/classifications.module\";\r\nimport { Configuration, configurationFactory } from \"src/infrastructure/configuration/configuration\";\r\nimport { LocaleService } from \"src/infrastructure/locale.service\";\r\nimport { PagesModule } from \"src/pages/pages.module\";\r\nimport { PublicationModule } from \"src/publication/publication.module\";\r\nimport { ComponentsModule } from \"../components/components.module\";\r\nimport { NgBootstrapModule } from \"../infrastructure/ng-bootstrap.module\";\r\nimport { SearchModule } from \"../search/search.module\";\r\nimport { AppRoutingModule } from \"./app-routing.module\";\r\nimport { AppComponent } from \"./app.component\";\r\nimport { FooterComponent } from \"./components/footer.component\";\r\nimport { MenuComponent } from \"./components/menu.component\";\r\nimport { PageNotFoundComponent } from \"./components/page-not-found.component\";\r\nimport { RedirectRewardComponent } from \"./components/redirect-reward.component\";\r\nimport { EAuthResource } from \"./e-auth/e-auth.resource\";\r\nimport { EAuthSendRequestModalComponent } from \"./e-auth/components/e-auth-send-request-modal.component\";\r\nimport { NgbActiveModal, NgbModule } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { EAuthUserService } from \"./e-auth/services/e-auth-user.service\";\r\nimport { EAuthProfileModalComponent } from \"./e-auth/components/e-auth-profile-modal.component\";\r\nimport { EAuthResponseComponent } from \"./e-auth/components/e-auth-response.component\";\r\n\r\nexport function HttpLoaderFactory(http: HttpClient) {\r\n return new TranslateHttpLoader(http);\r\n}\r\n\r\n@NgModule({\r\n declarations: [\r\n AppComponent,\r\n MenuComponent,\r\n FooterComponent,\r\n PageNotFoundComponent,\r\n RedirectRewardComponent,\r\n EAuthSendRequestModalComponent,\r\n EAuthProfileModalComponent,\r\n EAuthResponseComponent\r\n ],\r\n imports: [\r\n CommonModule,\r\n BrowserModule,\r\n HttpClientModule,\r\n TranslateModule.forRoot({\r\n loader: {\r\n provide: TranslateLoader,\r\n useFactory: HttpLoaderFactory,\r\n deps: [HttpClient]\r\n }\r\n }),\r\n FontAwesomeModule,\r\n NgbModule,\r\n NgBootstrapModule,\r\n ComponentsModule,\r\n SearchModule,\r\n PublicationModule,\r\n ClassificationsModule,\r\n PagesModule,\r\n AppRoutingModule\r\n ],\r\n entryComponents: [\r\n EAuthSendRequestModalComponent,\r\n EAuthProfileModalComponent\r\n ],\r\n providers: [\r\n Configuration,\r\n EAuthResource,\r\n EAuthUserService,\r\n NgbActiveModal,\r\n {\r\n provide: APP_INITIALIZER,\r\n useFactory: configurationFactory,\r\n deps: [Configuration],\r\n multi: true\r\n },\r\n LocaleService,\r\n {\r\n provide: LOCALE_ID,\r\n deps: [LocaleService],\r\n useFactory: (LocaleService: { locale: string }) => LocaleService.locale\r\n }\r\n ],\r\n bootstrap: [AppComponent]\r\n})\r\nexport class AppModule { }\r\n","module.exports = \".btn {\\n border-radius: 1px;\\n}\\n\\n.cursor-pointer {\\n cursor: pointer;\\n}\\n\\n.link {\\n text-decoration: underline;\\n color: #0072b5;\\n cursor: pointer;\\n -webkit-transition: color 0.1s ease-in;\\n transition: color 0.1s ease-in;\\n}\\n\\n.link:hover {\\n color: #002236;\\n}\\n\\n.link.primary {\\n color: #0072b5;\\n text-decoration: none;\\n font-weight: bold;\\n}\\n\\n.link.primary:hover {\\n color: #ff9800;\\n}\\n\\n.link-white, #footer-links a {\\n color: #ffffff;\\n text-decoration: none;\\n font-weight: bold;\\n cursor: pointer;\\n -webkit-transition: color 0.1s ease-in;\\n transition: color 0.1s ease-in;\\n}\\n\\n.link-white:hover, #footer-links a:hover {\\n color: #ff9800;\\n}\\n\\n.badge {\\n padding: 4px 8px;\\n font-weight: normal;\\n border: 1px solid transparent;\\n border-radius: 2px;\\n}\\n\\n.badge {\\n margin-left: 4px;\\n}\\n\\n.badge.pill {\\n border-radius: 15px;\\n padding: 4px 10px;\\n}\\n\\n.badge.default {\\n border-color: #b4b4b4;\\n color: #696969;\\n font-style: italic;\\n}\\n\\n.badge.default:hover {\\n cursor: pointer;\\n color: #ff9800;\\n border-color: #ff9800;\\n}\\n\\n.badge.secondary-outlined {\\n border-color: #ff9800;\\n color: #e68900;\\n font-weight: bold;\\n}\\n\\n.badge.secondary-contained {\\n background-color: #ff9800;\\n color: black;\\n}\\n\\n.badge.primary-outlined {\\n border-color: #0072b5;\\n color: #0072b5;\\n font-weight: bold;\\n}\\n\\n.badge.primary-contained {\\n background-color: #0072b5;\\n color: #ffffff;\\n}\\n\\n.badge.creators-badge {\\n background-color: #696969;\\n color: #ffffff;\\n}\\n\\nfooter {\\n position: relative;\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-orient: vertical;\\n -webkit-box-direction: normal;\\n flex-direction: column;\\n margin-top: 60px;\\n}\\n\\nfooter a {\\n color: #ffffff;\\n}\\n\\nfooter a:hover {\\n color: #ffffff;\\n text-decoration: none;\\n}\\n\\n#footer-links {\\n position: relative;\\n padding: 60px 0px 60px 0px;\\n background: #0072b5;\\n width: 100%;\\n color: #ffffff;\\n background: #0072b5;\\n background-image: url('home_2.jpg');\\n background-size: cover;\\n background-repeat: no-repeat;\\n}\\n\\n#footer-links a {\\n font-weight: normal;\\n}\\n\\n#footer-links h6 {\\n font-weight: bold;\\n color: #ff9800;\\n}\\n\\n#footer-links .flex-column {\\n line-height: 36px;\\n margin-top: 36px;\\n}\\n\\n#footer-links .scroll-up-row {\\n height: 44px;\\n width: 100%;\\n margin: 0;\\n padding: 0;\\n position: absolute;\\n top: 0;\\n left: 0;\\n -webkit-transform: translate(0%, -50%);\\n transform: translate(0%, -50%);\\n}\\n\\n#footer-links .scroll-up {\\n height: 44px;\\n width: 44px;\\n border-radius: 8px;\\n border: none;\\n box-shadow: inset 6px 6px 15px #0092e8, inset -6px -6px 15px #005282;\\n}\\n\\n#footer-social-media {\\n padding: 32px 0px;\\n}\\n\\n#footer-social-media a + a {\\n margin-left: 16px;\\n}\\n\\n#footer-copyright {\\n padding: 0px 0px 32px 0px;\\n font-size: 14px;\\n}\\n\\n@media screen and (max-width: 425px) {\\n .seal-label {\\n display: none;\\n }\\n}\\n\\n@media screen and (max-width: 768px) {\\n #footer-social-media > div {\\n -webkit-box-orient: vertical;\\n -webkit-box-direction: normal;\\n flex-direction: column;\\n }\\n\\n .trusted-seal {\\n margin-right: 0 !important;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\app\\components\\footer.component.scss","src/app/components/footer.component.scss","src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/stdin"],"names":[],"mappings":"AAEA;EACE,kBAAA;ACDF;;ADIA;EACE,eAAA;ACDF;;ADIA;EACE,0BAAA;EACA,cEXK;EFYL,eAAA;EACA,sCAAA;EAAA,8BAAA;ACDF;;ADGE;EACE,cAAA;ACDJ;;ADIE;EACE,cEpBG;EFqBH,qBAAA;EACA,iBAAA;ACFJ;;ADII;EACE,cErBG;ADmBT;;ADOA;EACE,cEzBM;EF0BN,qBAAA;EACA,iBAAA;EACA,eAAA;EACA,sCAAA;EAAA,8BAAA;ACJF;;ADME;EACE,cElCK;AD8BT;;ADQA;EACE,gBAAA;EACA,mBAAA;EACA,6BAAA;EACA,kBAAA;ACLF;;ADOE;EACE,gBAAA;ACLJ;;ADQE;EACE,mBAAA;EACA,iBAAA;ACNJ;;ADSE;EACE,qBEnDG;EFoDH,cEnDK;EFoDL,kBAAA;ACPJ;;ADSI;EACE,eAAA;EACA,cE5DG;EF6DH,qBE7DG;ADsDT;;ADWE;EACE,qBElEK;EFmEL,cAAA;EACA,iBAAA;ACTJ;;ADYE;EACE,yBExEK;EFyEL,YEpEI;AD0DR;;ADaE;EACE,qBEjFG;EFkFH,cElFG;EFmFH,iBAAA;ACXJ;;ADcE;EACE,yBEvFG;EFwFH,cElFI;ADsER;;ADeE;EACE,yBEpFK;EFqFL,cEvFI;AD0ER;;AE9EA;EACE,kBAAA;EACA,oBAAA;EAAA,aAAA;EACA,4BAAA;EAAA,6BAAA;UAAA,sBAAA;EACA,gBAAA;AFiFF;;AE/EE;EACE,cDHI;ADoFR;;AEhFI;EACE,cDLE;ECMF,qBAAA;AFkFN;;AE7EA;EACE,kBAAA;EACA,0BAAA;EACA,mBDpBK;ECqBL,WAAA;EACA,cDhBM;ECiBN,mBDvBK;ECwBL,mCAAA;EACA,sBAAA;EACA,4BAAA;AFgFF;;AE9EE;EAGE,mBAAA;AF8EJ;;AE3EE;EACE,iBAAA;EACA,cDhCK;AD6GT;;AE1EE;EACE,iBAAA;EACA,gBAAA;AF4EJ;;AEzEE;EACE,YAAA;EACA,WAAA;EACA,SAAA;EACA,UAAA;EACA,kBAAA;EACA,MAAA;EACA,OAAA;EACA,sCAAA;UAAA,8BAAA;AF2EJ;;AExEE;EACE,YAAA;EACA,WAAA;EACA,kBAAA;EACA,YAAA;EACA,oEAAA;AF0EJ;;AErEA;EACE,iBAAA;AFwEF;;AEvEE;EACE,iBAAA;AFyEJ;;AErEA;EACE,yBAAA;EACA,eAAA;AFwEF;;AErEA;EACE;IACE,aAAA;EFwEF;AACF;;AErEA;EACE;IACE,4BAAA;IAAA,6BAAA;YAAA,sBAAA;EFuEF;;EEpEA;IACE,0BAAA;EFuEF;AACF","file":"src/app/components/footer.component.scss","sourcesContent":["@import \"./variables.scss\";\r\n\r\n.btn {\r\n  border-radius: 1px;\r\n}\r\n\r\n.cursor-pointer {\r\n  cursor: pointer;\r\n}\r\n\r\n.link {\r\n  text-decoration: underline;\r\n  color: $primary;\r\n  cursor: pointer;\r\n  transition: color .1s ease-in;\r\n\r\n  &:hover {\r\n    color: darken($color: $primary, $amount: 25%);\r\n  }\r\n\r\n  &.primary {\r\n    color: $primary;\r\n    text-decoration: none;\r\n    font-weight: bold;\r\n\r\n    &:hover {\r\n      color: $secondary;\r\n    }\r\n  }\r\n}\r\n\r\n.link-white {\r\n  color: $white;\r\n  text-decoration: none;\r\n  font-weight: bold;\r\n  cursor: pointer;\r\n  transition: color .1s ease-in;\r\n\r\n  &:hover {\r\n    color: $secondary;\r\n  }\r\n}\r\n\r\n.badge {\r\n  padding: 4px 8px;\r\n  font-weight: normal;\r\n  border: 1px solid transparent;\r\n  border-radius: 2px;\r\n\r\n  & {\r\n    margin-left: 4px;\r\n  }\r\n\r\n  &.pill {\r\n    border-radius: 15px;\r\n    padding: 4px 10px;\r\n  }\r\n\r\n  &.default {\r\n    border-color: $gray;\r\n    color: $normal;\r\n    font-style: italic;\r\n\r\n    &:hover {\r\n      cursor: pointer;\r\n      color: $secondary;\r\n      border-color: $secondary;\r\n    }\r\n  }\r\n\r\n  &.secondary-outlined {\r\n    border-color: $secondary;\r\n    color: darken($secondary, 5%);\r\n    font-weight: bold;\r\n  }\r\n\r\n  &.secondary-contained {\r\n    background-color: $secondary;\r\n    color: $black;\r\n  }\r\n\r\n  &.primary-outlined {\r\n    border-color: $primary;\r\n    color: $primary;\r\n    font-weight: bold;\r\n  }\r\n\r\n  &.primary-contained {\r\n    background-color: $primary;\r\n    color: $white;\r\n  }\r\n\r\n  &.creators-badge {\r\n    background-color: $normal;\r\n    color: $white;\r\n  }\r\n}",".btn {\n  border-radius: 1px;\n}\n\n.cursor-pointer {\n  cursor: pointer;\n}\n\n.link {\n  text-decoration: underline;\n  color: #0072b5;\n  cursor: pointer;\n  transition: color 0.1s ease-in;\n}\n.link:hover {\n  color: #002236;\n}\n.link.primary {\n  color: #0072b5;\n  text-decoration: none;\n  font-weight: bold;\n}\n.link.primary:hover {\n  color: #ff9800;\n}\n\n.link-white, #footer-links a {\n  color: #ffffff;\n  text-decoration: none;\n  font-weight: bold;\n  cursor: pointer;\n  transition: color 0.1s ease-in;\n}\n.link-white:hover, #footer-links a:hover {\n  color: #ff9800;\n}\n\n.badge {\n  padding: 4px 8px;\n  font-weight: normal;\n  border: 1px solid transparent;\n  border-radius: 2px;\n}\n.badge {\n  margin-left: 4px;\n}\n.badge.pill {\n  border-radius: 15px;\n  padding: 4px 10px;\n}\n.badge.default {\n  border-color: #b4b4b4;\n  color: #696969;\n  font-style: italic;\n}\n.badge.default:hover {\n  cursor: pointer;\n  color: #ff9800;\n  border-color: #ff9800;\n}\n.badge.secondary-outlined {\n  border-color: #ff9800;\n  color: #e68900;\n  font-weight: bold;\n}\n.badge.secondary-contained {\n  background-color: #ff9800;\n  color: black;\n}\n.badge.primary-outlined {\n  border-color: #0072b5;\n  color: #0072b5;\n  font-weight: bold;\n}\n.badge.primary-contained {\n  background-color: #0072b5;\n  color: #ffffff;\n}\n.badge.creators-badge {\n  background-color: #696969;\n  color: #ffffff;\n}\n\nfooter {\n  position: relative;\n  display: flex;\n  flex-direction: column;\n  margin-top: 60px;\n}\nfooter a {\n  color: #ffffff;\n}\nfooter a:hover {\n  color: #ffffff;\n  text-decoration: none;\n}\n\n#footer-links {\n  position: relative;\n  padding: 60px 0px 60px 0px;\n  background: #0072b5;\n  width: 100%;\n  color: #ffffff;\n  background: #0072b5;\n  background-image: url(\"../../assets/img/home_2.jpg\");\n  background-size: cover;\n  background-repeat: no-repeat;\n}\n#footer-links a {\n  font-weight: normal;\n}\n#footer-links h6 {\n  font-weight: bold;\n  color: #ff9800;\n}\n#footer-links .flex-column {\n  line-height: 36px;\n  margin-top: 36px;\n}\n#footer-links .scroll-up-row {\n  height: 44px;\n  width: 100%;\n  margin: 0;\n  padding: 0;\n  position: absolute;\n  top: 0;\n  left: 0;\n  transform: translate(0%, -50%);\n}\n#footer-links .scroll-up {\n  height: 44px;\n  width: 44px;\n  border-radius: 8px;\n  border: none;\n  box-shadow: inset 6px 6px 15px #0092e8, inset -6px -6px 15px #005282;\n}\n\n#footer-social-media {\n  padding: 32px 0px;\n}\n#footer-social-media a + a {\n  margin-left: 16px;\n}\n\n#footer-copyright {\n  padding: 0px 0px 32px 0px;\n  font-size: 14px;\n}\n\n@media screen and (max-width: 425px) {\n  .seal-label {\n    display: none;\n  }\n}\n@media screen and (max-width: 768px) {\n  #footer-social-media > div {\n    flex-direction: column;\n  }\n\n  .trusted-seal {\n    margin-right: 0 !important;\n  }\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","@import \"../../variables\";\r\n@import \"../../common\";\r\n\r\nfooter{\r\n  position: relative;\r\n  display: flex;\r\n  flex-direction: column;\r\n  margin-top: 60px;\r\n\r\n  a {\r\n    color: $white;\r\n    &:hover {\r\n      color: $white;\r\n      text-decoration: none;\r\n    }\r\n  }\r\n}\r\n\r\n#footer-links {\r\n  position: relative;\r\n  padding: 60px 0px 60px 0px;\r\n  background: $primary;\r\n  width: 100%;\r\n  color: $white;\r\n  background: $primary;\r\n  background-image: url('../../assets/img/home_2.jpg');\r\n  background-size: cover;\r\n  background-repeat: no-repeat;\r\n\r\n  a {\r\n    @extend .link-white;\r\n\r\n    font-weight: normal;\r\n  }\r\n\r\n  h6 {\r\n    font-weight: bold;\r\n    color: $secondary;\r\n  }\r\n\r\n  .flex-column {\r\n    line-height: 36px;\r\n    margin-top: 36px;\r\n  }\r\n\r\n  .scroll-up-row {\r\n    height: 44px;\r\n    width: 100%;\r\n    margin: 0;\r\n    padding: 0;\r\n    position: absolute;\r\n    top: 0;\r\n    left: 0;\r\n    transform: translate(0%, -50%);\r\n  }\r\n\r\n  .scroll-up {\r\n    height: 44px;\r\n    width: 44px;\r\n    border-radius: 8px;\r\n    border: none;\r\n    box-shadow: inset 6px 6px 15px lighten($color: $primary, $amount: 10%), \r\n             inset -6px -6px 15px darken($color: $primary, $amount: 10%);\r\n  }\r\n}\r\n\r\n#footer-social-media {\r\n  padding: 32px 0px;\r\n  a + a {\r\n    margin-left: 16px;\r\n  }\r\n}\r\n\r\n#footer-copyright {\r\n  padding: 0px 0px 32px 0px;\r\n  font-size: 14px;\r\n}\r\n\r\n@media screen and (max-width: 425px) {\r\n  .seal-label {\r\n    display: none;\r\n  }\r\n}\r\n\r\n@media screen and (max-width: 768px) {\r\n  #footer-social-media > div {\r\n    flex-direction: column;\r\n  }\r\n\r\n  .trusted-seal {\r\n    margin-right: 0 !important;\r\n  }\r\n}"]} */\"","import { Component } from \"@angular/core\";\r\nimport { faFacebookSquare, faInstagram, faLinkedinIn, faPinterest, faTwitter, faYoutube } from '@fortawesome/free-brands-svg-icons';\r\nimport { faAngleUp } from '@fortawesome/free-solid-svg-icons';\r\nimport { LangChangeEvent, TranslateService } from '@ngx-translate/core';\r\nimport { scrollToTop } from 'src/infrastructure/utils';\r\n\r\n@Component({\r\n\tselector: 'ab-footer',\r\n\ttemplateUrl: 'footer.component.html',\r\n\tstyleUrls: ['footer.component.scss']\r\n})\r\nexport class FooterComponent {\r\n\tfaAngleUp = faAngleUp;\r\n\tfaFacebookSquare = faFacebookSquare;\r\n\tfaInstagram = faInstagram;\r\n\tfaTwitter = faTwitter;\r\n\tfaLinkedinIn = faLinkedinIn;\r\n\tfaPinterest = faPinterest;\r\n\tfaYoutube = faYoutube;\r\n\tcurrentLang: string = '';\r\n\tcurrentYear = new Date().getFullYear();\r\n\r\n\tconstructor(\r\n\t\ttranslateService: TranslateService\r\n\t) {\r\n\t\ttranslateService.onLangChange.subscribe((e: LangChangeEvent) => this.currentLang = e.lang);\r\n\t}\r\n\r\n\totherLinks = [\r\n\t\t{ url: 'https://explore.openaire.eu', name: 'footer.other.openair' },\r\n\t\t{ url: 'https://www.eosc-portal.eu', name: 'footer.other.eosc' },\r\n\t\t{ url: 'https://www.eoscsecretariat.eu', name: 'footer.other.eoscsecretariat' },\r\n\t\t{ url: 'https://www.eosc-hub.eu/services', name: 'footer.other.eoschub' },\r\n\t\t{ url: 'https://rda.bg/', name: 'footer.other.rda' },\r\n\t\t{ url: 'https://doaj.org', name: 'footer.other.doaj' },\r\n\t\t{ url: 'https://v2.sherpa.ac.uk/opendoar', name: 'footer.other.doar' },\r\n\t\t{ url: 'http://sherpa.ac.uk/romeo/index.php', name: 'footer.other.SherpaRoMEO' },\r\n\t\t{ url: 'https://www.esfri.eu', name: 'footer.other.esfri' },\r\n\t\t{ url: 'https://ec.europa.eu/info/horizon-europe-next-research-and-innovation-framework-programme_en', name: 'footer.other.horizon' },\r\n\t];\r\n\r\n\tscrollToTop() {\r\n\t\tscrollToTop();\r\n\t}\r\n}\r\n","module.exports = \"nav {\\n font-size: 16px;\\n font-weight: bold;\\n color: black;\\n margin-top: -8px;\\n padding-left: 0px;\\n padding-right: 0px;\\n}\\nnav a {\\n margin: 8px 10px 0px 10px;\\n padding: 8px 12px;\\n box-sizing: content-box;\\n color: inherit;\\n border-bottom: 3px solid transparent;\\n -webkit-transition: all 0.1s ease-in;\\n transition: all 0.1s ease-in;\\n}\\nnav a.active {\\n padding: 8px 16px;\\n border-radius: 8px;\\n background-color: #ff9800;\\n color: #ffffff;\\n}\\nnav a:hover:not(.active):not(.navbar-brand) {\\n color: black;\\n border-bottom: 3px solid #ff9800;\\n}\\nnav ab-language-selector {\\n margin-top: 8px;\\n}\\nnav .nav-link {\\n display: inline-block;\\n}\\nnav hr {\\n display: none;\\n}\\nnav .lang-select {\\n margin-top: 4px;\\n}\\n@media (max-width: 1199.98px) {\\n #navigation-collapsed-content {\\n padding: 1rem 26px 0px 26px;\\n box-shadow: 0px -1px 8px 0px lightgray;\\n }\\n #navigation-collapsed-content hr {\\n display: block;\\n margin: initial 26px;\\n }\\n #navigation-collapsed-content div {\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-pack: center;\\n justify-content: center;\\n -webkit-box-align: center;\\n align-items: center;\\n }\\n #navigation-collapsed-content a.active {\\n background-color: #ffffff;\\n color: #ff9800;\\n }\\n #navigation-collapsed-content a:hover:not(.active):not(.navbar-brand) {\\n color: #ff9800;\\n border-bottom: 3px solid transparent;\\n }\\n #navigation-collapsed-content .lang-select {\\n margin-top: 24px;\\n margin-bottom: 24px;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\app\\components\\menu.component.scss","src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/app/components/menu.component.scss","src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAGA;EACE,eAAA;EACA,iBAAA;EACA,YCIM;EDHN,gBAAA;EACA,iBAAA;EACA,kBAAA;AEFF;AFOE;EACE,yBAAA;EACA,iBAAA;EACA,uBAAA;EACA,cAAA;EACA,oCAAA;EACA,oCAAA;EAAA,4BAAA;AELJ;AFOI;EACE,iBAAA;EACA,kBAAA;EACA,yBCpBG;EDsBH,cCpBE;ACcR;AFSI;EACE,YCrBE;EDsBF,gCAAA;AEPN;AFWE;EACE,eAAA;AETJ;AFYE;EACE,qBAAA;AEVJ;AFaE;EACE,aAAA;AEXJ;AFcE;EACE,eAAA;AEZJ;ACoCI;EHnBF;IACE,2BAAA;IACA,sCAAA;EEbF;EFeE;IACE,cAAA;IACA,oBAAA;EEbJ;EFgBE;IAEE,oBAAA;IAAA,aAAA;IACA,wBAAA;YAAA,uBAAA;IACA,yBAAA;YAAA,mBAAA;EEfJ;EFmBI;IACE,yBCjEA;IDkEA,cCpEC;ECmDP;EFoBI;IACE,cCxEC;IDyED,oCAAA;EElBN;EFsBE;IACE,gBAAA;IACA,mBAAA;EEpBJ;AACF","file":"src/app/components/menu.component.scss","sourcesContent":["@import '../../variables';\r\n@import '../../mixins';\r\n\r\nnav {\r\n  font-size: 16px;\r\n  font-weight: bold;\r\n  color: $black;\r\n  margin-top: -8px;\r\n  padding-left: 0px;\r\n  padding-right: 0px;\r\n  // #navigation-collapsed-content {\r\n  //   margin-top: ;\r\n  // }\r\n\r\n  a {\r\n    margin: 8px 10px 0px 10px;\r\n    padding: 8px 12px;\r\n    box-sizing: content-box;\r\n    color: inherit;\r\n    border-bottom: 3px solid transparent;\r\n    transition: all .1s ease-in;\r\n\r\n    &.active {\r\n      padding: 8px 16px;\r\n      border-radius: 8px;\r\n      background-color: $secondary;\r\n      // color: darken($primary, 20%);\r\n      color: $white;\r\n    }\r\n\r\n    &:hover:not(.active):not(.navbar-brand) {\r\n      color: $black;\r\n      border-bottom: 3px solid $secondary;\r\n    }\r\n  }\r\n\r\n  ab-language-selector {\r\n    margin-top: 8px;\r\n  }\r\n\r\n  .nav-link {\r\n    display: inline-block;\r\n  }\r\n\r\n  hr {\r\n    display: none;\r\n  }\r\n\r\n  .lang-select {\r\n    margin-top: 4px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down('lg') {\r\n  #navigation-collapsed-content {\r\n    padding: 1rem 26px 0px 26px;\r\n    box-shadow: 0px -1px 8px 0px lightgray;\r\n\r\n    hr {\r\n      display: block;\r\n      margin: initial 26px;\r\n    }\r\n\r\n    div {\r\n      \r\n      display: flex;\r\n      justify-content: center;\r\n      align-items: center;\r\n    }\r\n\r\n    a {\r\n      &.active {\r\n        background-color: $white;\r\n        color: $secondary;\r\n      }\r\n\r\n      &:hover:not(.active):not(.navbar-brand) {\r\n        color: $secondary;\r\n        border-bottom: 3px solid transparent;\r\n      }\r\n    }\r\n\r\n    .lang-select {\r\n      margin-top: 24px;\r\n      margin-bottom: 24px;\r\n    }\r\n  }\r\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","nav {\n  font-size: 16px;\n  font-weight: bold;\n  color: black;\n  margin-top: -8px;\n  padding-left: 0px;\n  padding-right: 0px;\n}\nnav a {\n  margin: 8px 10px 0px 10px;\n  padding: 8px 12px;\n  box-sizing: content-box;\n  color: inherit;\n  border-bottom: 3px solid transparent;\n  transition: all 0.1s ease-in;\n}\nnav a.active {\n  padding: 8px 16px;\n  border-radius: 8px;\n  background-color: #ff9800;\n  color: #ffffff;\n}\nnav a:hover:not(.active):not(.navbar-brand) {\n  color: black;\n  border-bottom: 3px solid #ff9800;\n}\nnav ab-language-selector {\n  margin-top: 8px;\n}\nnav .nav-link {\n  display: inline-block;\n}\nnav hr {\n  display: none;\n}\nnav .lang-select {\n  margin-top: 4px;\n}\n\n@media (max-width: 1199.98px) {\n  #navigation-collapsed-content {\n    padding: 1rem 26px 0px 26px;\n    box-shadow: 0px -1px 8px 0px lightgray;\n  }\n  #navigation-collapsed-content hr {\n    display: block;\n    margin: initial 26px;\n  }\n  #navigation-collapsed-content div {\n    display: flex;\n    justify-content: center;\n    align-items: center;\n  }\n  #navigation-collapsed-content a.active {\n    background-color: #ffffff;\n    color: #ff9800;\n  }\n  #navigation-collapsed-content a:hover:not(.active):not(.navbar-brand) {\n    color: #ff9800;\n    border-bottom: 3px solid transparent;\n  }\n  #navigation-collapsed-content .lang-select {\n    margin-top: 24px;\n    margin-bottom: 24px;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, HostListener, ViewChild, ElementRef } from \"@angular/core\";\r\nimport { faBars } from '@fortawesome/free-solid-svg-icons';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\r\nimport { TranslateService, LangChangeEvent } from '@ngx-translate/core';\r\nimport { EAuthSendRequestModalComponent } from \"../e-auth/components/e-auth-send-request-modal.component\";\r\nimport { NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { EAuthUserService } from \"../e-auth/services/e-auth-user.service\";\r\nimport { EAuthProfileModalComponent } from \"../e-auth/components/e-auth-profile-modal.component\";\r\n\r\n@Component({\r\n selector: 'ab-menu',\r\n templateUrl: 'menu.component.html',\r\n styleUrls: ['menu.component.scss']\r\n})\r\nexport class MenuComponent {\r\n\r\n constructor(\r\n config: Configuration,\r\n sanitizer: DomSanitizer,\r\n translate: TranslateService,\r\n private modalService: NgbModal,\r\n public eAuthUserService: EAuthUserService\r\n ) {\r\n this.loginUrl = sanitizer.bypassSecurityTrustUrl(`${config.internalAppUrl}/login`);\r\n translate.onLangChange.subscribe((e: LangChangeEvent) => this.lang = e.lang);\r\n }\r\n\r\n lang: string;\r\n loginUrl: SafeUrl;\r\n faBars = faBars;\r\n\r\n @ViewChild(\"collapseContainer\", { static: false }) collapseContainer: ElementRef;\r\n @ViewChild('toggleBtn', { static: true }) toggleBtn: ElementRef;\r\n\r\n @HostListener('document:click', ['$event']) onClickOutside(event: MouseEvent): void {\r\n if (!this.collapseContainer.nativeElement.contains(event.target)\r\n && this.collapseContainer.nativeElement.classList.contains('show'))\r\n this.toggleBtn.nativeElement.click();\r\n }\r\n\r\n hideCollapseContainer(container: HTMLElement) {\r\n setTimeout(() => this.collapseContainer.nativeElement.classList.remove('show'), 100)\r\n }\r\n\r\n loginEAuth() {\r\n this.modalService.open(EAuthSendRequestModalComponent, { size: 'lg', keyboard: false, backdrop: 'static' });\r\n }\r\n\r\n profileEAuth() {\r\n this.modalService.open(EAuthProfileModalComponent, { keyboard: false, backdrop: 'static' });\r\n }\r\n}","module.exports = \".not-found {\\n -webkit-user-select: none;\\n -moz-user-select: none;\\n -ms-user-select: none;\\n user-select: none;\\n font-size: 242px;\\n color: #f2f2f2;\\n font-weight: bold;\\n text-align: center;\\n position: relative;\\n}\\n.not-found fa-icon {\\n position: absolute;\\n top: 50%;\\n left: 50%;\\n color: #0072b5;\\n font-size: 75px;\\n -webkit-transform: translate(-40%, -35%);\\n transform: translate(-40%, -35%);\\n}\\n.not-found-text {\\n -webkit-user-select: none;\\n -moz-user-select: none;\\n -ms-user-select: none;\\n user-select: none;\\n max-width: 570px;\\n margin: 0 auto;\\n color: #0072b5;\\n font-weight: bold;\\n font-size: 30px;\\n text-align: center;\\n text-transform: uppercase;\\n}\\n@media (max-width: 767.98px) {\\n .not-found {\\n font-size: 160px;\\n }\\n .not-found fa-icon {\\n font-size: 60px;\\n }\\n\\n .not-found-text {\\n font-size: 24px;\\n }\\n}\\n@media (max-width: 575.98px) {\\n .not-found {\\n font-size: 120px;\\n }\\n .not-found fa-icon {\\n font-size: 40px;\\n }\\n\\n .not-found-text {\\n font-size: 22px;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\app\\components\\page-not-found.component.scss","src/app/components/page-not-found.component.scss","src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/app/components/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAGA;EACE,yBAAA;KAAA,sBAAA;MAAA,qBAAA;UAAA,iBAAA;EACA,gBAAA;EACA,cAAA;EACA,iBAAA;EACA,kBAAA;EACA,kBAAA;ACFF;ADIE;EACE,kBAAA;EACA,QAAA;EACA,SAAA;EACA,cEdG;EFeH,eAAA;EACA,wCAAA;UAAA,gCAAA;ACFJ;ADMA;EACE,yBAAA;KAAA,sBAAA;MAAA,qBAAA;UAAA,iBAAA;EACA,gBAAA;EACA,cAAA;EACA,cExBK;EFyBL,iBAAA;EACA,eAAA;EACA,kBAAA;EACA,yBAAA;ACHF;AE+CI;EHxCF;IACE,gBAAA;ECHF;EDKE;IACE,eAAA;ECHJ;;EDOA;IACE,eAAA;ECJF;AACF;AEkCI;EH1BF;IACE,gBAAA;ECLF;EDOE;IACE,eAAA;ECLJ;;EDSA;IACE,eAAA;ECNF;AACF","file":"src/app/components/page-not-found.component.scss","sourcesContent":["@import '../../variables';\r\n@import '../../mixins';\r\n\r\n.not-found {\r\n  user-select: none;\r\n  font-size: 242px;\r\n  color: #f2f2f2;\r\n  font-weight: bold;\r\n  text-align: center;\r\n  position: relative;\r\n\r\n  fa-icon {\r\n    position: absolute;\r\n    top: 50%;\r\n    left: 50%;\r\n    color: $primary;\r\n    font-size: 75px;\r\n    transform: translate(-40%, -35%);\r\n  }\r\n}\r\n\r\n.not-found-text {\r\n  user-select: none;\r\n  max-width: 570px;\r\n  margin: 0 auto;\r\n  color: $primary;\r\n  font-weight: bold;\r\n  font-size: 30px;\r\n  text-align: center;\r\n  text-transform: uppercase;\r\n}\r\n\r\n@include media-breakpoint-down('sm') {\r\n  .not-found {\r\n    font-size: 160px;\r\n\r\n    fa-icon {\r\n      font-size: 60px;\r\n    }\r\n  }\r\n\r\n  .not-found-text {\r\n    font-size: 24px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down('xs') {\r\n  .not-found {\r\n    font-size: 120px;\r\n\r\n    fa-icon {\r\n      font-size: 40px;\r\n    }\r\n  }\r\n\r\n  .not-found-text {\r\n    font-size: 22px;\r\n  }\r\n}\r\n\r\n",".not-found {\n  user-select: none;\n  font-size: 242px;\n  color: #f2f2f2;\n  font-weight: bold;\n  text-align: center;\n  position: relative;\n}\n.not-found fa-icon {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  color: #0072b5;\n  font-size: 75px;\n  transform: translate(-40%, -35%);\n}\n\n.not-found-text {\n  user-select: none;\n  max-width: 570px;\n  margin: 0 auto;\n  color: #0072b5;\n  font-weight: bold;\n  font-size: 30px;\n  text-align: center;\n  text-transform: uppercase;\n}\n\n@media (max-width: 767.98px) {\n  .not-found {\n    font-size: 160px;\n  }\n  .not-found fa-icon {\n    font-size: 60px;\n  }\n\n  .not-found-text {\n    font-size: 24px;\n  }\n}\n@media (max-width: 575.98px) {\n  .not-found {\n    font-size: 120px;\n  }\n  .not-found fa-icon {\n    font-size: 40px;\n  }\n\n  .not-found-text {\n    font-size: 22px;\n  }\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component } from '@angular/core';\r\nimport { faSearch } from '@fortawesome/free-solid-svg-icons';\r\n\r\n@Component({\r\n templateUrl: 'page-not-found.component.html',\r\n styleUrls: ['page-not-found.component.scss']\r\n})\r\nexport class PageNotFoundComponent {\r\n faSearch = faSearch\r\n}","import { Component, OnInit } from \"@angular/core\";\r\nimport { Configuration } from \"src/infrastructure/configuration/configuration\";\r\n\r\n@Component({\r\n selector: \"app-reward-redirect\",\r\n template: \"\"\r\n})\r\nexport class RedirectRewardComponent implements OnInit {\r\n constructor(\r\n private configuration: Configuration\r\n ) { }\r\n\r\n ngOnInit(): void {\r\n window.location.href = `${this.configuration.internalAppUrl}/reward`;\r\n }\r\n}\r\n","import { Component } from \"@angular/core\";\r\nimport { NgbActiveModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { EAuthUserService } from \"../services/e-auth-user.service\";\r\nimport { faTimes } from '@fortawesome/free-solid-svg-icons';\r\n\r\n@Component({\r\n selector: 'e-auth-profile-modal',\r\n templateUrl: './e-auth-profile-modal.component.html'\r\n})\r\nexport class EAuthProfileModalComponent {\r\n\r\n faTimes = faTimes;\r\n\r\n constructor(\r\n private activeModal: NgbActiveModal,\r\n public eAuthUserService: EAuthUserService\r\n ) {\r\n }\r\n\r\n close() {\r\n this.activeModal.close(null);\r\n }\r\n\r\n exit() {\r\n this.eAuthUserService.isLogged = false;\r\n this.eAuthUserService.userName = null;\r\n this.close();\r\n }\r\n}","import { Component, OnInit } from \"@angular/core\";\r\nimport { EAuthResponseStatus } from \"../enums/e-auth-response-status.enum\";\r\nimport { ActivatedRoute, Router } from \"@angular/router\";\r\nimport { EAuthUserService } from \"../services/e-auth-user.service\";\r\n\r\n@Component({\r\n selector: 'e-auth-response',\r\n templateUrl: './e-auth-response.component.html'\r\n})\r\nexport class EAuthResponseComponent implements OnInit {\r\n\r\n responseStatus: any;\r\n errorMessage: string;\r\n\r\n constructor(\r\n private router: Router,\r\n private route: ActivatedRoute,\r\n private eAuthUserService: EAuthUserService\r\n ) {\r\n }\r\n\r\n ngOnInit() {\r\n this.responseStatus = EAuthResponseStatus[this.route.snapshot.queryParams.responseStatus];\r\n\r\n if (this.responseStatus === EAuthResponseStatus.Success) {\r\n this.eAuthUserService.isLogged = true;\r\n this.eAuthUserService.userName = this.route.snapshot.queryParams.name;\r\n this.router.navigate(['/']);\r\n } else {\r\n this.setErrorMessage();\r\n }\r\n }\r\n\r\n setErrorMessage() {\r\n if (this.responseStatus === EAuthResponseStatus.AuthenticationFailed) {\r\n this.errorMessage = 'Проблем при автентикацията';\r\n }\r\n if (this.responseStatus === EAuthResponseStatus.CanceledByUser) {\r\n this.errorMessage = 'Процеса е прекъснат от потребител';\r\n }\r\n if (this.responseStatus === EAuthResponseStatus.InvalidResponseXML) {\r\n this.errorMessage = 'Грешка в генерирания XML';\r\n }\r\n if (this.responseStatus === EAuthResponseStatus.InvalidSignature) {\r\n this.errorMessage = 'Невалиден подпис';\r\n }\r\n if (this.responseStatus === EAuthResponseStatus.MissingEGN) {\r\n this.errorMessage = 'Липсва ЕГН';\r\n }\r\n if (this.responseStatus === EAuthResponseStatus.NotDetectedQES) {\r\n this.errorMessage = 'Подписът не е КЕП';\r\n }\r\n }\r\n}","import { Component, OnInit } from \"@angular/core\";\r\nimport { SamlRequestDto } from \"../dtos/saml-request.dto\";\r\nimport { NgbActiveModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { EAuthResource } from \"../e-auth.resource\";\r\nimport { catchError } from \"rxjs/operators\";\r\nimport { HttpErrorResponse } from \"@angular/common/http\";\r\nimport { throwError } from \"rxjs\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { faTimes } from '@fortawesome/free-solid-svg-icons';\r\n\r\n@Component({\r\n selector: 'e-auth-send-request-modal',\r\n templateUrl: './e-auth-send-request-modal.component.html'\r\n})\r\nexport class EAuthSendRequestModalComponent implements OnInit {\r\n\r\n faTimes = faTimes;\r\n samlRequest: SamlRequestDto = null;\r\n isLoading = false;\r\n\r\n constructor(\r\n private activeModal: NgbActiveModal,\r\n private eAuthResource: EAuthResource,\r\n private sanitizer: DomSanitizer\r\n ) {\r\n }\r\n\r\n login(url: string) {\r\n if (url) {\r\n return this.sanitizer.bypassSecurityTrustResourceUrl(url);\r\n }\r\n }\r\n\r\n close() {\r\n this.activeModal.close(null);\r\n }\r\n\r\n ngOnInit() {\r\n this.isLoading = true;\r\n this.eAuthResource.getSamlRequest()\r\n .pipe(\r\n catchError((err: HttpErrorResponse) => {\r\n\r\n this.isLoading = false;\r\n this.close();\r\n return throwError(() => new Error('Invalid login.'));\r\n })\r\n )\r\n .subscribe((samlRequest: SamlRequestDto) => {\r\n this.samlRequest = samlRequest;\r\n this.isLoading = false;\r\n });\r\n }\r\n}","import { HttpClient } from \"@angular/common/http\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { SamlRequestDto } from \"./dtos/saml-request.dto\";\r\nimport { Observable } from \"rxjs\";\r\n\r\n@Injectable()\r\nexport class EAuthResource {\r\n\r\n url = 'api/EAuth';\r\n\r\n constructor(\r\n private http: HttpClient\r\n ) {\r\n }\r\n\r\n getSamlRequest(): Observable {\r\n return this.http.get(`${this.url}`);\r\n }\r\n}","export enum EAuthResponseStatus {\r\n CanceledByUser = 1,\r\n AuthenticationFailed = 2,\r\n InvalidResponseXML = 3,\r\n InvalidSignature = 4,\r\n MissingEGN = 5,\r\n NotDetectedQES = 6,\r\n Success = 7\r\n}\r\n","import { Injectable } from \"@angular/core\";\r\n\r\n@Injectable()\r\nexport class EAuthUserService {\r\n isLogged = false;\r\n userName: string = null;\r\n}","import { NgModule } from \"@angular/core\";\r\nimport { OrganizationComponent } from './components/organization/organization.component';\r\nimport { ScientificAreaComponent } from './components/scientific-area/scientific-area.component';\r\nimport { ClassificationsRouting } from './classifications.routing';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { ScientificAreasDataResolverService } from './services/scientific-area-data-resolver.service';\r\nimport { OrganizationsDataResolverService } from './services/organization-data-resolver.service';\r\nimport { OrganizationViewComponent } from './components/organization-view/organization-view.component';\r\nimport { OrganizationViewDataResolverService } from './services/organization-view-data-resolver.service';\r\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\r\nimport { ComponentsModule } from 'src/components/components.module';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n TranslateModule,\r\n FontAwesomeModule,\r\n ComponentsModule,\r\n ClassificationsRouting\r\n ],\r\n declarations: [\r\n OrganizationComponent,\r\n ScientificAreaComponent,\r\n OrganizationViewComponent\r\n ],\r\n providers: [\r\n ScientificAreasDataResolverService,\r\n OrganizationsDataResolverService,\r\n OrganizationViewDataResolverService\r\n ]\r\n})\r\nexport class ClassificationsModule { }","import { NgModule } from '@angular/core';\r\nimport { RouterModule, Routes } from '@angular/router';\r\nimport { OrganizationComponent } from './components/organization/organization.component';\r\nimport { OrganizationsDataResolverService } from './services/organization-data-resolver.service';\r\n\r\nconst routes: Routes = [\r\n {\r\n path: 'organizations',\r\n children: [\r\n {\r\n path: '',\r\n component: OrganizationComponent,\r\n data: {\r\n title: 'pages.organizations'\r\n },\r\n resolve: {\r\n data: OrganizationsDataResolverService\r\n }\r\n }\r\n ]\r\n }\r\n];\r\n\r\n@NgModule({\r\n imports: [RouterModule.forChild(routes)],\r\n exports: [RouterModule],\r\n})\r\n\r\nexport class ClassificationsRouting { }","module.exports = \".root .classification-root {\\n padding: 12px 0px 0px 20px;\\n}\\n.root .classification-name {\\n font-size: 18px;\\n font-family: \\\"Roboto Slab\\\", serif;\\n color: #0072b5;\\n}\\n.root .classification-name.clickable:hover {\\n cursor: pointer;\\n text-decoration: underline;\\n}\\n.root .search-icon {\\n color: #0072b5;\\n margin-left: 8px;\\n cursor: pointer;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jbGFzc2lmaWNhdGlvbnMvY29tcG9uZW50cy9vcmdhbml6YXRpb24tdmlldy9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFxjbGFzc2lmaWNhdGlvbnNcXGNvbXBvbmVudHNcXG9yZ2FuaXphdGlvbi12aWV3XFxvcmdhbml6YXRpb24tdmlldy5jb21wb25lbnQuc2NzcyIsInNyYy9jbGFzc2lmaWNhdGlvbnMvY29tcG9uZW50cy9vcmdhbml6YXRpb24tdmlldy9vcmdhbml6YXRpb24tdmlldy5jb21wb25lbnQuc2NzcyIsInNyYy9jbGFzc2lmaWNhdGlvbnMvY29tcG9uZW50cy9vcmdhbml6YXRpb24tdmlldy9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFx2YXJpYWJsZXMuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHRTtFQUNFLDBCQUFBO0FDRko7QURNRTtFQUNFLGVBQUE7RUFDQSxpQ0FBQTtFQUNBLGNFVkc7QURNUDtBRE1JO0VBQ0UsZUFBQTtFQUNBLDBCQUFBO0FDSk47QURRRTtFQUNFLGNFbkJHO0VGb0JILGdCQUFBO0VBQ0EsZUFBQTtBQ05KIiwiZmlsZSI6InNyYy9jbGFzc2lmaWNhdGlvbnMvY29tcG9uZW50cy9vcmdhbml6YXRpb24tdmlldy9vcmdhbml6YXRpb24tdmlldy5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIkBpbXBvcnQgJy4uLy4uLy4uL3ZhcmlhYmxlcyc7XHJcblxyXG4ucm9vdCB7XHJcbiAgLmNsYXNzaWZpY2F0aW9uLXJvb3Qge1xyXG4gICAgcGFkZGluZzogMTJweCAgMHB4IDBweCAyMHB4O1xyXG4gICAgLy9ib3JkZXI6IDFweCBkYXNoZWQgJHNlY29uZGFyeTtcclxuICB9XHJcblxyXG4gIC5jbGFzc2lmaWNhdGlvbi1uYW1lIHtcclxuICAgIGZvbnQtc2l6ZTogMThweDtcclxuICAgIGZvbnQtZmFtaWx5OiAnUm9ib3RvIFNsYWInLCBzZXJpZjtcclxuICAgIGNvbG9yOiAkcHJpbWFyeTtcclxuXHJcbiAgICAmLmNsaWNrYWJsZTpob3ZlciB7XHJcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcclxuICAgICAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAuc2VhcmNoLWljb24ge1xyXG4gICAgY29sb3I6ICRwcmltYXJ5O1xyXG4gICAgbWFyZ2luLWxlZnQ6IDhweDtcclxuICAgIGN1cnNvcjogcG9pbnRlcjtcclxuICB9XHJcbn0iLCIucm9vdCAuY2xhc3NpZmljYXRpb24tcm9vdCB7XG4gIHBhZGRpbmc6IDEycHggMHB4IDBweCAyMHB4O1xufVxuLnJvb3QgLmNsYXNzaWZpY2F0aW9uLW5hbWUge1xuICBmb250LXNpemU6IDE4cHg7XG4gIGZvbnQtZmFtaWx5OiBcIlJvYm90byBTbGFiXCIsIHNlcmlmO1xuICBjb2xvcjogIzAwNzJiNTtcbn1cbi5yb290IC5jbGFzc2lmaWNhdGlvbi1uYW1lLmNsaWNrYWJsZTpob3ZlciB7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG59XG4ucm9vdCAuc2VhcmNoLWljb24ge1xuICBjb2xvcjogIzAwNzJiNTtcbiAgbWFyZ2luLWxlZnQ6IDhweDtcbiAgY3Vyc29yOiBwb2ludGVyO1xufSIsIi8vICRibHVlOiAjMTkwZThmO1xyXG4kYmx1ZTogIzAwNzJiNTtcclxuLy8gJGJsdWU6ICNBOEIxMEU7XHJcbi8vICRwYXN0ZWwtYmx1ZTogI0E4QjEwRTtcclxuJHBhc3RlbC1ibHVlOiAjMDA3MmI1O1xyXG4kb3JhbmdlOiAjZmY5ODAwO1xyXG4kcGFzdGVsLW9yYW5nZTogI0ZGQjg0RDtcclxuJHdoaXRlOiAjZmZmZmZmO1xyXG4kZ3JheTogI2I0YjRiNDtcclxuJG5vcm1hbDogIzY5Njk2OTtcclxuJGJsYWNrOiBkYXJrZW4oJG5vcm1hbCwgNzUlKTtcclxuXHJcbiRwcmltYXJ5OiAkYmx1ZTtcclxuJHNlY29uZGFyeTogJG9yYW5nZTtcclxuXHJcbiR0aGVtZS1jb2xvcnMgOiAoXHJcbiAgXCJzZWNvbmRhcnlcIjogICRzZWNvbmRhcnksXHJcbiAgXCJub3JtYWxcIjogJG5vcm1hbCxcclxuICBcInBhc3RlbC1ibHVlXCI6ICRwYXN0ZWwtYmx1ZSxcclxuICBcInBhc3RlbC1vcmFuZ2VcIjogJHBhc3RlbC1vcmFuZ2VcclxuKTtcclxuXHJcbiRncmlkLWJyZWFrcG9pbnRzOiAoXHJcbiAgeHM6IDAsXHJcbiAgc206IDU3NnB4LFxyXG4gIG1kOiA3NjhweCxcclxuICBsZzogOTkycHgsXHJcbiAgeGw6IDEyMDBweFxyXG4pO1xyXG5cclxuJGNvbnRhaW5lci1tYXgtd2lkdGhzOiAoXHJcbiAgc206IDc2OHB4LFxyXG4gIG1kOiA5NTlweCxcclxuICBsZzogOTYwcHgsXHJcbiAgeGw6IDEyMDBweFxyXG4pO1xyXG5cclxuJGlucHV0LWJvcmRlci1zaXplOiAxcHg7XHJcbiRib3JkZXItc2l6ZTogMnB4OyJdfQ== */\"","import { Component } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { faSearch } from '@fortawesome/free-solid-svg-icons';\r\nimport { SearchField } from 'src/search/models/search-field';\r\nimport { SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { Classification } from 'src/classifications/models/classification';\r\nimport { SearchState } from 'src/search/services/search.state';\r\n\r\n@Component({\r\n selector: 'app-organization-view',\r\n templateUrl: './organization-view.component.html',\r\n styleUrls: [\r\n '../../styles/common.scss',\r\n './organization-view.component.scss'\r\n ]\r\n})\r\nexport class OrganizationViewComponent {\r\n constructor(\r\n private route: ActivatedRoute,\r\n private router: Router,\r\n private state: SearchState\r\n ) {\r\n this.route.data.subscribe(({ data }) => this.organization = data);\r\n }\r\n\r\n organization: Classification;\r\n faSearch = faSearch;\r\n\r\n clickClassification(classification: Classification) {\r\n // If we are not in a leaf node\r\n if (classification.children && classification.children.length > 0) {\r\n classification.isOpen = !classification.isOpen;\r\n }\r\n // If we are in a leaf node\r\n else {\r\n this.selectClassification(classification);\r\n }\r\n }\r\n\r\n selectClassification(classification: Classification) {\r\n this.state.change$.next({\r\n q: [new SearchField(SearchFieldType.classifications, classification.id, classification)]\r\n });\r\n this.router.navigate(['/search']);\r\n }\r\n}\r\n","module.exports = \".link.primary {\\n font-weight: bold;\\n}\\n\\n.organization-box {\\n padding: 8px;\\n background-color: whitesmoke;\\n}\\n\\n.organization-box fa-icon {\\n margin-right: 4px;\\n}\\n\\n.organization-box + .organization-box {\\n margin-top: 16px;\\n}\\n\\n.classification-root {\\n padding: 8px 0px 0px 16px;\\n}\\n\\n.classification-name {\\n color: #0072b5;\\n}\\n\\n.classification-name.clickable:hover {\\n cursor: pointer;\\n}\\n\\n.search-icon {\\n font-size: 14px;\\n color: #0072b5;\\n margin-left: 8px;\\n cursor: pointer;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jbGFzc2lmaWNhdGlvbnMvY29tcG9uZW50cy9vcmdhbml6YXRpb24vQzpcXFByb2plY3RzXFxvcGVuc2NpZW5jZVxcUG9ydGFsLldlYkFwcGxpY2F0aW9uL3NyY1xcY2xhc3NpZmljYXRpb25zXFxjb21wb25lbnRzXFxvcmdhbml6YXRpb25cXG9yZ2FuaXphdGlvbi5jb21wb25lbnQuc2NzcyIsInNyYy9jbGFzc2lmaWNhdGlvbnMvY29tcG9uZW50cy9vcmdhbml6YXRpb24vb3JnYW5pemF0aW9uLmNvbXBvbmVudC5zY3NzIiwic3JjL2NsYXNzaWZpY2F0aW9ucy9jb21wb25lbnRzL29yZ2FuaXphdGlvbi9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFx2YXJpYWJsZXMuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQTtFQUNFLGlCQUFBO0FDRkY7O0FES0E7RUFDRSxZQUFBO0VBQ0EsNEJBQUE7QUNGRjs7QURJRTtFQUNFLGlCQUFBO0FDRko7O0FETUE7RUFDRSxnQkFBQTtBQ0hGOztBRFlBO0VBQ0UseUJBQUE7QUNURjs7QURhQTtFQUNFLGNFL0JLO0FEcUJQOztBRFlFO0VBQ0UsZUFBQTtBQ1ZKOztBRGNBO0VBQ0UsZUFBQTtFQUNBLGNFeENLO0VGeUNMLGdCQUFBO0VBQ0EsZUFBQTtBQ1hGIiwiZmlsZSI6InNyYy9jbGFzc2lmaWNhdGlvbnMvY29tcG9uZW50cy9vcmdhbml6YXRpb24vb3JnYW5pemF0aW9uLmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiQGltcG9ydCAnLi4vLi4vLi4vdmFyaWFibGVzJztcclxuQGltcG9ydCAnLi4vLi4vLi4vbWl4aW5zJztcclxuXHJcbi5saW5rLnByaW1hcnkge1xyXG4gIGZvbnQtd2VpZ2h0OiBib2xkO1xyXG59XHJcblxyXG4ub3JnYW5pemF0aW9uLWJveCB7XHJcbiAgcGFkZGluZzogOHB4O1xyXG4gIGJhY2tncm91bmQtY29sb3I6IHdoaXRlc21va2U7XHJcblxyXG4gIGZhLWljb24ge1xyXG4gICAgbWFyZ2luLXJpZ2h0OiA0cHg7XHJcbiAgfVxyXG59XHJcblxyXG4ub3JnYW5pemF0aW9uLWJveCArIC5vcmdhbml6YXRpb24tYm94IHtcclxuICBtYXJnaW4tdG9wOiAxNnB4O1xyXG59XHJcblxyXG4vLyAuY29udGVudCB7XHJcbi8vICAgZGl2ICsgZGl2e1xyXG4vLyAgICAgbWFyZ2luLXRvcDogMTZweDtcclxuLy8gICB9XHJcbi8vIH1cclxuXHJcbi5jbGFzc2lmaWNhdGlvbi1yb290IHtcclxuICBwYWRkaW5nOiA4cHggIDBweCAwcHggMTZweDtcclxuICAvL2JvcmRlcjogMXB4IGRhc2hlZCAkc2Vjb25kYXJ5O1xyXG59XHJcblxyXG4uY2xhc3NpZmljYXRpb24tbmFtZSB7XHJcbiAgY29sb3I6ICRwcmltYXJ5O1xyXG5cclxuICAmLmNsaWNrYWJsZTpob3ZlciB7XHJcbiAgICBjdXJzb3I6IHBvaW50ZXI7XHJcbiAgfVxyXG59XHJcblxyXG4uc2VhcmNoLWljb24ge1xyXG4gIGZvbnQtc2l6ZTogMTRweDtcclxuICBjb2xvcjogJHByaW1hcnk7XHJcbiAgbWFyZ2luLWxlZnQ6IDhweDtcclxuICBjdXJzb3I6IHBvaW50ZXI7XHJcbn0iLCIubGluay5wcmltYXJ5IHtcbiAgZm9udC13ZWlnaHQ6IGJvbGQ7XG59XG5cbi5vcmdhbml6YXRpb24tYm94IHtcbiAgcGFkZGluZzogOHB4O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZXNtb2tlO1xufVxuLm9yZ2FuaXphdGlvbi1ib3ggZmEtaWNvbiB7XG4gIG1hcmdpbi1yaWdodDogNHB4O1xufVxuXG4ub3JnYW5pemF0aW9uLWJveCArIC5vcmdhbml6YXRpb24tYm94IHtcbiAgbWFyZ2luLXRvcDogMTZweDtcbn1cblxuLmNsYXNzaWZpY2F0aW9uLXJvb3Qge1xuICBwYWRkaW5nOiA4cHggMHB4IDBweCAxNnB4O1xufVxuXG4uY2xhc3NpZmljYXRpb24tbmFtZSB7XG4gIGNvbG9yOiAjMDA3MmI1O1xufVxuLmNsYXNzaWZpY2F0aW9uLW5hbWUuY2xpY2thYmxlOmhvdmVyIHtcbiAgY3Vyc29yOiBwb2ludGVyO1xufVxuXG4uc2VhcmNoLWljb24ge1xuICBmb250LXNpemU6IDE0cHg7XG4gIGNvbG9yOiAjMDA3MmI1O1xuICBtYXJnaW4tbGVmdDogOHB4O1xuICBjdXJzb3I6IHBvaW50ZXI7XG59IiwiLy8gJGJsdWU6ICMxOTBlOGY7XHJcbiRibHVlOiAjMDA3MmI1O1xyXG4vLyAkYmx1ZTogI0E4QjEwRTtcclxuLy8gJHBhc3RlbC1ibHVlOiAjQThCMTBFO1xyXG4kcGFzdGVsLWJsdWU6ICMwMDcyYjU7XHJcbiRvcmFuZ2U6ICNmZjk4MDA7XHJcbiRwYXN0ZWwtb3JhbmdlOiAjRkZCODREO1xyXG4kd2hpdGU6ICNmZmZmZmY7XHJcbiRncmF5OiAjYjRiNGI0O1xyXG4kbm9ybWFsOiAjNjk2OTY5O1xyXG4kYmxhY2s6IGRhcmtlbigkbm9ybWFsLCA3NSUpO1xyXG5cclxuJHByaW1hcnk6ICRibHVlO1xyXG4kc2Vjb25kYXJ5OiAkb3JhbmdlO1xyXG5cclxuJHRoZW1lLWNvbG9ycyA6IChcclxuICBcInNlY29uZGFyeVwiOiAgJHNlY29uZGFyeSxcclxuICBcIm5vcm1hbFwiOiAkbm9ybWFsLFxyXG4gIFwicGFzdGVsLWJsdWVcIjogJHBhc3RlbC1ibHVlLFxyXG4gIFwicGFzdGVsLW9yYW5nZVwiOiAkcGFzdGVsLW9yYW5nZVxyXG4pO1xyXG5cclxuJGdyaWQtYnJlYWtwb2ludHM6IChcclxuICB4czogMCxcclxuICBzbTogNTc2cHgsXHJcbiAgbWQ6IDc2OHB4LFxyXG4gIGxnOiA5OTJweCxcclxuICB4bDogMTIwMHB4XHJcbik7XHJcblxyXG4kY29udGFpbmVyLW1heC13aWR0aHM6IChcclxuICBzbTogNzY4cHgsXHJcbiAgbWQ6IDk1OXB4LFxyXG4gIGxnOiA5NjBweCxcclxuICB4bDogMTIwMHB4XHJcbik7XHJcblxyXG4kaW5wdXQtYm9yZGVyLXNpemU6IDFweDtcclxuJGJvcmRlci1zaXplOiAycHg7Il19 */\"","import { Component } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { } from '@fortawesome/free-regular-svg-icons';\r\nimport { faCaretDown, faCaretRight, faDatabase, faSearch } from '@fortawesome/free-solid-svg-icons';\r\nimport { Classification } from 'src/classifications/models/classification';\r\nimport { SearchField } from 'src/search/models/search-field';\r\nimport { SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { SearchState } from 'src/search/services/search.state';\r\n\r\n@Component({\r\n templateUrl: './organization.component.html',\r\n styleUrls: ['../../../page-styles.scss', './organization.component.scss']\r\n})\r\nexport class OrganizationComponent {\r\n constructor(\r\n route: ActivatedRoute,\r\n private router: Router,\r\n private state: SearchState\r\n ) {\r\n route.data.subscribe(({ data }) => {\r\n this.data = data;\r\n });\r\n }\r\n\r\n SearchFieldType = SearchFieldType;\r\n data: Classification[] = [];\r\n\r\n collectionIcon = faDatabase;\r\n closedIcon = faCaretRight;\r\n openIcon = faCaretDown;\r\n faSearch = faSearch;\r\n\r\n back() {\r\n window.history.back();\r\n }\r\n\r\n clickClassification(classification: Classification) {\r\n // If we are not in a leaf node\r\n if (classification.children && classification.children.length > 0) {\r\n classification.isOpen = !classification.isOpen;\r\n }\r\n // If we are in a leaf node\r\n else {\r\n this.selectSearchFiled(SearchFieldType.classifications, classification.id, classification);\r\n }\r\n }\r\n\r\n clickOrganization(institution: Classification) {\r\n if (institution.children && institution.children.length) {\r\n institution.isOpen = !institution.isOpen;\r\n } else {\r\n this.selectSearchFiled(SearchFieldType.institution, institution.id, institution);\r\n }\r\n }\r\n\r\n private selectSearchFiled(type: SearchFieldType, value: number, model: Classification) {\r\n this.state.change$.next({\r\n q: [new SearchField(type, value, model)]\r\n });\r\n this.router.navigate(['/search']);\r\n }\r\n}\r\n","module.exports = \".root .main-areas-container {\\n -webkit-box-pack: space-evenly;\\n justify-content: space-evenly;\\n}\\n.root .main-area {\\n width: 30%;\\n margin-bottom: 32px;\\n}\\n.root .main-title:hover {\\n text-decoration: none;\\n}\\n@media (max-width: 991.98px) {\\n .root .main-area {\\n width: 40%;\\n }\\n}\\n@media (max-width: 767.98px) {\\n .root .main-area {\\n width: 90%;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/classifications/components/scientific-area/C:\\Projects\\openscience\\Portal.WebApplication/src\\classifications\\components\\scientific-area\\scientific-area.component.scss","src/classifications/components/scientific-area/scientific-area.component.scss","src/classifications/components/scientific-area/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAIE;EACE,8BAAA;UAAA,6BAAA;ACHJ;ADME;EACE,UAAA;EACA,mBAAA;ACJJ;ADOE;EACE,qBAAA;ACLJ;ACgEI;EFrDA;IACE,UAAA;ECPJ;AACF;AC0DI;EF7CA;IACE,UAAA;ECVJ;AACF","file":"src/classifications/components/scientific-area/scientific-area.component.scss","sourcesContent":["@import '../../../variables';\r\n@import '../../../mixins';\r\n\r\n.root {\r\n  .main-areas-container {\r\n    justify-content: space-evenly;\r\n  }\r\n\r\n  .main-area {\r\n    width: 30%;\r\n    margin-bottom: 32px;\r\n  }\r\n\r\n  .main-title:hover {\r\n    text-decoration: none;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"md\"){\r\n  .root {\r\n    .main-area {\r\n      width: 40%;\r\n    }\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"sm\"){\r\n  .root {\r\n    .main-area {\r\n      width: 90%;\r\n    }\r\n  }\r\n}",".root .main-areas-container {\n  justify-content: space-evenly;\n}\n.root .main-area {\n  width: 30%;\n  margin-bottom: 32px;\n}\n.root .main-title:hover {\n  text-decoration: none;\n}\n\n@media (max-width: 991.98px) {\n  .root .main-area {\n    width: 40%;\n  }\n}\n@media (max-width: 767.98px) {\n  .root .main-area {\n    width: 90%;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { SearchField } from 'src/search/models/search-field';\r\nimport { Classification } from 'src/classifications/models/classification';\r\nimport { SearchMode } from 'src/search/models/search-mode.enum';\r\n\r\n@Component({\r\n templateUrl: './scientific-area.component.html',\r\n styleUrls: [\r\n '../../styles/common.scss',\r\n './scientific-area.component.scss'\r\n ]\r\n})\r\nexport class ScientificAreaComponent {\r\n constructor(\r\n private route: ActivatedRoute,\r\n private router: Router\r\n ) {\r\n this.route.data.subscribe(({ data }) => {\r\n this.data = data;\r\n });\r\n }\r\n\r\n data: Classification[] = [];\r\n\r\n // area: Classification\r\n // [new SearchField(SearchFieldType.classifications, area.id, area)]\r\n}\r\n","import { Injectable } from \"@angular/core\";\r\nimport { Resolve, Router } from '@angular/router';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\nimport { take, mergeMap } from 'rxjs/operators';\r\nimport { of, EMPTY } from 'rxjs';\r\nimport { LoadingIndicatorService } from 'src/infrastructure/loading-indicator.service';\r\nimport { Classification } from '../models/classification';\r\nimport { SEARCH_FIELD_SPEC } from 'src/search/models/search-field-type-spec';\r\nimport { SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\n\r\n\r\n\r\n@Injectable()\r\nexport class OrganizationsDataResolverService implements Resolve {\r\n\r\n constructor(\r\n private http: HttpClient,\r\n private config: Configuration,\r\n private router: Router,\r\n private loadingIndicator: LoadingIndicatorService,\r\n private localService: LocaleService\r\n ) { }\r\n\r\n resolve() {\r\n this.loadingIndicator.start();\r\n\r\n let classificationsSpec = SEARCH_FIELD_SPEC[SearchFieldType.classifications];\r\n\r\n let query = {\r\n aggregations: {\r\n [classificationsSpec.name]: {\r\n terms: {\r\n field: classificationsSpec.name,\r\n size: 100000\r\n }\r\n }\r\n },\r\n size: 0\r\n };\r\n\r\n return this.http\r\n .post(`${this.config.restUrl}/institution/hierarchy?lang=${this.localService.culture}`, query)\r\n .pipe(\r\n mergeMap(hierarchy => {\r\n this.loadingIndicator.stop();\r\n if (hierarchy && hierarchy.length) {\r\n return of(hierarchy);\r\n }\r\n else {\r\n this.router.navigate(['/notFound']);\r\n return EMPTY;\r\n }\r\n })\r\n );\r\n }\r\n}","import { Injectable } from \"@angular/core\";\r\nimport { Resolve, Router, ActivatedRouteSnapshot } from '@angular/router';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\nimport { take, mergeMap } from 'rxjs/operators';\r\nimport { of, EMPTY } from 'rxjs';\r\nimport { LoadingIndicatorService } from 'src/infrastructure/loading-indicator.service';\r\nimport { SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { Classification } from '../models/classification';\r\nimport { SEARCH_FIELD_SPEC } from 'src/search/models/search-field-type-spec';\r\n\r\n@Injectable()\r\nexport class OrganizationViewDataResolverService implements Resolve {\r\n\r\n constructor(\r\n private http: HttpClient,\r\n private config: Configuration,\r\n private router: Router,\r\n private loadingIndicator: LoadingIndicatorService\r\n ) { }\r\n\r\n resolve(route: ActivatedRouteSnapshot) {\r\n let id = route.paramMap.get('id');\r\n let classificationsSpec = SEARCH_FIELD_SPEC[SearchFieldType.classifications];\r\n\r\n let query = {\r\n aggregations: {\r\n [classificationsSpec.name]: {\r\n terms: {\r\n field: classificationsSpec.name,\r\n size: 100000\r\n }\r\n }\r\n },\r\n size: 0\r\n };\r\n\r\n this.loadingIndicator.start();\r\n return this.http\r\n .post(`${this.config.restUrl}/institution/hierarchy/${id}`, query)\r\n .pipe(\r\n take(1),\r\n mergeMap((institution: Classification) => {\r\n this.loadingIndicator.stop();\r\n if (institution) {\r\n institution.children.forEach(classification => classification.isOpen = true);\r\n return of(institution);\r\n }\r\n else {\r\n this.router.navigate(['/notFound']);\r\n return EMPTY;\r\n }\r\n })\r\n );\r\n }\r\n}","import { Injectable } from \"@angular/core\";\r\nimport { Resolve, Router } from '@angular/router';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\nimport { take, mergeMap } from 'rxjs/operators';\r\nimport { of, EMPTY } from 'rxjs';\r\nimport { LoadingIndicatorService } from 'src/infrastructure/loading-indicator.service';\r\nimport { SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { Classification } from '../models/classification';\r\nimport { SEARCH_FIELD_SPEC } from 'src/search/models/search-field-type-spec';\r\n\r\n@Injectable()\r\nexport class ScientificAreasDataResolverService implements Resolve {\r\n\r\n constructor(\r\n private http: HttpClient,\r\n private config: Configuration,\r\n private router: Router,\r\n private loadingIndicator: LoadingIndicatorService\r\n ) { }\r\n\r\n resolve() {\r\n let classificationsSpec = SEARCH_FIELD_SPEC[SearchFieldType.classifications];\r\n\r\n let query = {\r\n aggregations: {\r\n [classificationsSpec.name]: {\r\n terms: {\r\n field: classificationsSpec.name,\r\n size: 100000\r\n }\r\n }\r\n },\r\n size: 0\r\n };\r\n\r\n this.loadingIndicator.start();\r\n return this.http\r\n .post(`${this.config.restUrl}/classification/hierarchy`, query)\r\n .pipe(\r\n take(1),\r\n mergeMap(hierarchy => {\r\n this.loadingIndicator.stop();\r\n if (hierarchy && hierarchy.length) {\r\n return of(hierarchy);\r\n }\r\n else {\r\n this.router.navigate(['/notFound']);\r\n return EMPTY;\r\n }\r\n })\r\n );\r\n }\r\n}","module.exports = \".container {\\n padding: 0;\\n}\\n\\n.root {\\n margin: 48px 0px;\\n padding: 16px;\\n border: 1px solid #0072b5;\\n border-radius: 20px;\\n background-color: #b5e4ff;\\n}\\n\\n.root .headline {\\n margin-bottom: 48px;\\n}\\n\\n.root .main-areas-container {\\n margin-top: 48px;\\n display: -webkit-box;\\n display: flex;\\n flex-wrap: wrap;\\n -webkit-box-align: start;\\n align-items: flex-start;\\n}\\n\\n.root .main-area {\\n font-family: \\\"Roboto Slab\\\", serif;\\n font-size: 18px;\\n}\\n\\n.root .main-area .main-title-container {\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-pack: justify;\\n justify-content: space-between;\\n -webkit-box-align: center;\\n align-items: center;\\n}\\n\\n.root .main-area .secondary-areas-container {\\n margin-left: 8px;\\n padding: 8px 0px 0px 8px;\\n}\\n\\n.root .secondary-area {\\n font-family: \\\"Roboto Condensed\\\", sans-serif;\\n font-size: 16px;\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-pack: justify;\\n justify-content: space-between;\\n -webkit-box-align: center;\\n align-items: center;\\n}\\n\\n.root .secondary-area .secondary-title {\\n -webkit-box-flex: 1;\\n flex-grow: 1;\\n color: black;\\n}\\n\\n.root .main-title:hover, .root .secondary-title:hover {\\n text-decoration: underline;\\n}\\n\\n@media (max-width: 991.98px) {\\n .root {\\n margin: 32px 32px;\\n }\\n}\\n\\n@media (max-width: 575.98px) {\\n .root {\\n margin: 32px 0px;\\n border-color: transparent;\\n background-color: transparent;\\n }\\n .root .main-area {\\n font-size: 16px;\\n }\\n .root .secondary-area {\\n font-size: 14px;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/classifications/styles/C:\\Projects\\openscience\\Portal.WebApplication/src\\classifications\\styles\\common.scss","src/classifications/styles/common.scss","src/classifications/styles/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/classifications/styles/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAGA;EACG,UAAA;ACFH;;ADKA;EACE,gBAAA;EACA,aAAA;EACA,yBAAA;EACA,mBAAA;EACA,yBAAA;ACFF;;ADIE;EACE,mBAAA;ACFJ;;ADKE;EACE,gBAAA;EACA,oBAAA;EAAA,aAAA;EACA,eAAA;EACA,wBAAA;UAAA,uBAAA;ACHJ;;ADME;EACE,iCAAA;EACA,eAAA;ACJJ;;ADMI;EACE,oBAAA;EAAA,aAAA;EACA,yBAAA;UAAA,8BAAA;EACA,yBAAA;UAAA,mBAAA;ACJN;;ADOI;EACE,gBAAA;EACA,wBAAA;ACLN;;ADSE;EACE,2CAAA;EACA,eAAA;EACA,oBAAA;EAAA,aAAA;EACA,yBAAA;UAAA,8BAAA;EACA,yBAAA;UAAA,mBAAA;ACPJ;;ADSI;EACE,mBAAA;UAAA,YAAA;EACA,YExCE;ADiCR;;ADWE;EACE,0BAAA;ACTJ;;AE2BI;EHbF;IACE,iBAAA;ECVF;AACF;;AEqBI;EHPF;IACE,gBAAA;IACA,yBAAA;IACA,6BAAA;ECXF;EDaE;IACE,eAAA;ECXJ;EDcE;IACE,eAAA;ECZJ;AACF","file":"src/classifications/styles/common.scss","sourcesContent":["@import '../../variables';\r\n@import '../../mixins';\r\n\r\n.container {\r\n   padding: 0;\r\n}\r\n\r\n.root {\r\n  margin: 48px 0px;\r\n  padding: 16px;\r\n  border: 1px solid $pastel-blue;\r\n  border-radius: 20px;\r\n  background-color: lighten($color: $pastel-blue, $amount: 50%);\r\n\r\n  .headline {\r\n    margin-bottom: 48px;\r\n  }\r\n\r\n  .main-areas-container {\r\n    margin-top: 48px;\r\n    display: flex;\r\n    flex-wrap: wrap;\r\n    align-items: flex-start;\r\n  }\r\n\r\n  .main-area {\r\n    font-family: 'Roboto Slab', serif;\r\n    font-size: 18px;\r\n    \r\n    .main-title-container {\r\n      display: flex;\r\n      justify-content: space-between;\r\n      align-items: center;\r\n    }\r\n\r\n    .secondary-areas-container {\r\n      margin-left: 8px;\r\n      padding: 8px 0px 0px 8px;\r\n    }\r\n  }\r\n\r\n  .secondary-area {\r\n    font-family: 'Roboto Condensed', sans-serif;\r\n    font-size: 16px;\r\n    display: flex;\r\n    justify-content: space-between;\r\n    align-items: center;\r\n\r\n    .secondary-title {\r\n      flex-grow: 1;\r\n      color: $black;\r\n    }\r\n  }\r\n\r\n  .main-title:hover, .secondary-title:hover {\r\n    text-decoration: underline;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"md\") {\r\n  .root {\r\n    margin:32px 32px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"xs\") {\r\n  .root {\r\n    margin: 32px 0px;\r\n    border-color: transparent;\r\n    background-color: transparent;\r\n    \r\n    .main-area {\r\n      font-size: 16px;\r\n    }\r\n\r\n    .secondary-area {\r\n      font-size: 14px;\r\n    }\r\n  }\r\n}",".container {\n  padding: 0;\n}\n\n.root {\n  margin: 48px 0px;\n  padding: 16px;\n  border: 1px solid #0072b5;\n  border-radius: 20px;\n  background-color: #b5e4ff;\n}\n.root .headline {\n  margin-bottom: 48px;\n}\n.root .main-areas-container {\n  margin-top: 48px;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: flex-start;\n}\n.root .main-area {\n  font-family: \"Roboto Slab\", serif;\n  font-size: 18px;\n}\n.root .main-area .main-title-container {\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n}\n.root .main-area .secondary-areas-container {\n  margin-left: 8px;\n  padding: 8px 0px 0px 8px;\n}\n.root .secondary-area {\n  font-family: \"Roboto Condensed\", sans-serif;\n  font-size: 16px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n}\n.root .secondary-area .secondary-title {\n  flex-grow: 1;\n  color: black;\n}\n.root .main-title:hover, .root .secondary-title:hover {\n  text-decoration: underline;\n}\n\n@media (max-width: 991.98px) {\n  .root {\n    margin: 32px 32px;\n  }\n}\n@media (max-width: 575.98px) {\n  .root {\n    margin: 32px 0px;\n    border-color: transparent;\n    background-color: transparent;\n  }\n  .root .main-area {\n    font-size: 16px;\n  }\n  .root .secondary-area {\n    font-size: 14px;\n  }\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","module.exports = \".btn {\\n border-radius: 1px;\\n}\\n\\n.cursor-pointer {\\n cursor: pointer;\\n}\\n\\n.link {\\n text-decoration: underline;\\n color: #0072b5;\\n cursor: pointer;\\n -webkit-transition: color 0.1s ease-in;\\n transition: color 0.1s ease-in;\\n}\\n\\n.link:hover {\\n color: #002236;\\n}\\n\\n.link.primary {\\n color: #0072b5;\\n text-decoration: none;\\n font-weight: bold;\\n}\\n\\n.link.primary:hover {\\n color: #ff9800;\\n}\\n\\n.link-white {\\n color: #ffffff;\\n text-decoration: none;\\n font-weight: bold;\\n cursor: pointer;\\n -webkit-transition: color 0.1s ease-in;\\n transition: color 0.1s ease-in;\\n}\\n\\n.link-white:hover {\\n color: #ff9800;\\n}\\n\\n.badge {\\n padding: 4px 8px;\\n font-weight: normal;\\n border: 1px solid transparent;\\n border-radius: 2px;\\n}\\n\\n.badge {\\n margin-left: 4px;\\n}\\n\\n.badge.pill {\\n border-radius: 15px;\\n padding: 4px 10px;\\n}\\n\\n.badge.default {\\n border-color: #b4b4b4;\\n color: #696969;\\n font-style: italic;\\n}\\n\\n.badge.default:hover {\\n cursor: pointer;\\n color: #ff9800;\\n border-color: #ff9800;\\n}\\n\\n.badge.secondary-outlined {\\n border-color: #ff9800;\\n color: #e68900;\\n font-weight: bold;\\n}\\n\\n.badge.secondary-contained {\\n background-color: #ff9800;\\n color: black;\\n}\\n\\n.badge.primary-outlined {\\n border-color: #0072b5;\\n color: #0072b5;\\n font-weight: bold;\\n}\\n\\n.badge.primary-contained {\\n background-color: #0072b5;\\n color: #ffffff;\\n}\\n\\n.badge.creators-badge {\\n background-color: #696969;\\n color: #ffffff;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFxjb21tb24uc2NzcyIsInNyYy9jb21tb24uc2NzcyIsInNyYy9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFx2YXJpYWJsZXMuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQTtFQUNFLGtCQUFBO0FDREY7O0FESUE7RUFDRSxlQUFBO0FDREY7O0FESUE7RUFDRSwwQkFBQTtFQUNBLGNFWEs7RUZZTCxlQUFBO0VBQ0Esc0NBQUE7RUFBQSw4QkFBQTtBQ0RGOztBREdFO0VBQ0UsY0FBQTtBQ0RKOztBRElFO0VBQ0UsY0VwQkc7RUZxQkgscUJBQUE7RUFDQSxpQkFBQTtBQ0ZKOztBRElJO0VBQ0UsY0VyQkc7QURtQlQ7O0FET0E7RUFDRSxjRXpCTTtFRjBCTixxQkFBQTtFQUNBLGlCQUFBO0VBQ0EsZUFBQTtFQUNBLHNDQUFBO0VBQUEsOEJBQUE7QUNKRjs7QURNRTtFQUNFLGNFbENLO0FEOEJUOztBRFFBO0VBQ0UsZ0JBQUE7RUFDQSxtQkFBQTtFQUNBLDZCQUFBO0VBQ0Esa0JBQUE7QUNMRjs7QURPRTtFQUNFLGdCQUFBO0FDTEo7O0FEUUU7RUFDRSxtQkFBQTtFQUNBLGlCQUFBO0FDTko7O0FEU0U7RUFDRSxxQkVuREc7RUZvREgsY0VuREs7RUZvREwsa0JBQUE7QUNQSjs7QURTSTtFQUNFLGVBQUE7RUFDQSxjRTVERztFRjZESCxxQkU3REc7QURzRFQ7O0FEV0U7RUFDRSxxQkVsRUs7RUZtRUwsY0FBQTtFQUNBLGlCQUFBO0FDVEo7O0FEWUU7RUFDRSx5QkV4RUs7RUZ5RUwsWUVwRUk7QUQwRFI7O0FEYUU7RUFDRSxxQkVqRkc7RUZrRkgsY0VsRkc7RUZtRkgsaUJBQUE7QUNYSjs7QURjRTtFQUNFLHlCRXZGRztFRndGSCxjRWxGSTtBRHNFUjs7QURlRTtFQUNFLHlCRXBGSztFRnFGTCxjRXZGSTtBRDBFUiIsImZpbGUiOiJzcmMvY29tbW9uLnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyJAaW1wb3J0IFwiLi92YXJpYWJsZXMuc2Nzc1wiO1xyXG5cclxuLmJ0biB7XHJcbiAgYm9yZGVyLXJhZGl1czogMXB4O1xyXG59XHJcblxyXG4uY3Vyc29yLXBvaW50ZXIge1xyXG4gIGN1cnNvcjogcG9pbnRlcjtcclxufVxyXG5cclxuLmxpbmsge1xyXG4gIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xyXG4gIGNvbG9yOiAkcHJpbWFyeTtcclxuICBjdXJzb3I6IHBvaW50ZXI7XHJcbiAgdHJhbnNpdGlvbjogY29sb3IgLjFzIGVhc2UtaW47XHJcblxyXG4gICY6aG92ZXIge1xyXG4gICAgY29sb3I6IGRhcmtlbigkY29sb3I6ICRwcmltYXJ5LCAkYW1vdW50OiAyNSUpO1xyXG4gIH1cclxuXHJcbiAgJi5wcmltYXJ5IHtcclxuICAgIGNvbG9yOiAkcHJpbWFyeTtcclxuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcclxuICAgIGZvbnQtd2VpZ2h0OiBib2xkO1xyXG5cclxuICAgICY6aG92ZXIge1xyXG4gICAgICBjb2xvcjogJHNlY29uZGFyeTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuXHJcbi5saW5rLXdoaXRlIHtcclxuICBjb2xvcjogJHdoaXRlO1xyXG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcclxuICBmb250LXdlaWdodDogYm9sZDtcclxuICBjdXJzb3I6IHBvaW50ZXI7XHJcbiAgdHJhbnNpdGlvbjogY29sb3IgLjFzIGVhc2UtaW47XHJcblxyXG4gICY6aG92ZXIge1xyXG4gICAgY29sb3I6ICRzZWNvbmRhcnk7XHJcbiAgfVxyXG59XHJcblxyXG4uYmFkZ2Uge1xyXG4gIHBhZGRpbmc6IDRweCA4cHg7XHJcbiAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcclxuICBib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcclxuICBib3JkZXItcmFkaXVzOiAycHg7XHJcblxyXG4gICYge1xyXG4gICAgbWFyZ2luLWxlZnQ6IDRweDtcclxuICB9XHJcblxyXG4gICYucGlsbCB7XHJcbiAgICBib3JkZXItcmFkaXVzOiAxNXB4O1xyXG4gICAgcGFkZGluZzogNHB4IDEwcHg7XHJcbiAgfVxyXG5cclxuICAmLmRlZmF1bHQge1xyXG4gICAgYm9yZGVyLWNvbG9yOiAkZ3JheTtcclxuICAgIGNvbG9yOiAkbm9ybWFsO1xyXG4gICAgZm9udC1zdHlsZTogaXRhbGljO1xyXG5cclxuICAgICY6aG92ZXIge1xyXG4gICAgICBjdXJzb3I6IHBvaW50ZXI7XHJcbiAgICAgIGNvbG9yOiAkc2Vjb25kYXJ5O1xyXG4gICAgICBib3JkZXItY29sb3I6ICRzZWNvbmRhcnk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAmLnNlY29uZGFyeS1vdXRsaW5lZCB7XHJcbiAgICBib3JkZXItY29sb3I6ICRzZWNvbmRhcnk7XHJcbiAgICBjb2xvcjogZGFya2VuKCRzZWNvbmRhcnksIDUlKTtcclxuICAgIGZvbnQtd2VpZ2h0OiBib2xkO1xyXG4gIH1cclxuXHJcbiAgJi5zZWNvbmRhcnktY29udGFpbmVkIHtcclxuICAgIGJhY2tncm91bmQtY29sb3I6ICRzZWNvbmRhcnk7XHJcbiAgICBjb2xvcjogJGJsYWNrO1xyXG4gIH1cclxuXHJcbiAgJi5wcmltYXJ5LW91dGxpbmVkIHtcclxuICAgIGJvcmRlci1jb2xvcjogJHByaW1hcnk7XHJcbiAgICBjb2xvcjogJHByaW1hcnk7XHJcbiAgICBmb250LXdlaWdodDogYm9sZDtcclxuICB9XHJcblxyXG4gICYucHJpbWFyeS1jb250YWluZWQge1xyXG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHByaW1hcnk7XHJcbiAgICBjb2xvcjogJHdoaXRlO1xyXG4gIH1cclxuXHJcbiAgJi5jcmVhdG9ycy1iYWRnZSB7XHJcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkbm9ybWFsO1xyXG4gICAgY29sb3I6ICR3aGl0ZTtcclxuICB9XHJcbn0iLCIuYnRuIHtcbiAgYm9yZGVyLXJhZGl1czogMXB4O1xufVxuXG4uY3Vyc29yLXBvaW50ZXIge1xuICBjdXJzb3I6IHBvaW50ZXI7XG59XG5cbi5saW5rIHtcbiAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG4gIGNvbG9yOiAjMDA3MmI1O1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIHRyYW5zaXRpb246IGNvbG9yIDAuMXMgZWFzZS1pbjtcbn1cbi5saW5rOmhvdmVyIHtcbiAgY29sb3I6ICMwMDIyMzY7XG59XG4ubGluay5wcmltYXJ5IHtcbiAgY29sb3I6ICMwMDcyYjU7XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgZm9udC13ZWlnaHQ6IGJvbGQ7XG59XG4ubGluay5wcmltYXJ5OmhvdmVyIHtcbiAgY29sb3I6ICNmZjk4MDA7XG59XG5cbi5saW5rLXdoaXRlIHtcbiAgY29sb3I6ICNmZmZmZmY7XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgZm9udC13ZWlnaHQ6IGJvbGQ7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgdHJhbnNpdGlvbjogY29sb3IgMC4xcyBlYXNlLWluO1xufVxuLmxpbmstd2hpdGU6aG92ZXIge1xuICBjb2xvcjogI2ZmOTgwMDtcbn1cblxuLmJhZGdlIHtcbiAgcGFkZGluZzogNHB4IDhweDtcbiAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgYm9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG4gIGJvcmRlci1yYWRpdXM6IDJweDtcbn1cbi5iYWRnZSB7XG4gIG1hcmdpbi1sZWZ0OiA0cHg7XG59XG4uYmFkZ2UucGlsbCB7XG4gIGJvcmRlci1yYWRpdXM6IDE1cHg7XG4gIHBhZGRpbmc6IDRweCAxMHB4O1xufVxuLmJhZGdlLmRlZmF1bHQge1xuICBib3JkZXItY29sb3I6ICNiNGI0YjQ7XG4gIGNvbG9yOiAjNjk2OTY5O1xuICBmb250LXN0eWxlOiBpdGFsaWM7XG59XG4uYmFkZ2UuZGVmYXVsdDpob3ZlciB7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgY29sb3I6ICNmZjk4MDA7XG4gIGJvcmRlci1jb2xvcjogI2ZmOTgwMDtcbn1cbi5iYWRnZS5zZWNvbmRhcnktb3V0bGluZWQge1xuICBib3JkZXItY29sb3I6ICNmZjk4MDA7XG4gIGNvbG9yOiAjZTY4OTAwO1xuICBmb250LXdlaWdodDogYm9sZDtcbn1cbi5iYWRnZS5zZWNvbmRhcnktY29udGFpbmVkIHtcbiAgYmFja2dyb3VuZC1jb2xvcjogI2ZmOTgwMDtcbiAgY29sb3I6IGJsYWNrO1xufVxuLmJhZGdlLnByaW1hcnktb3V0bGluZWQge1xuICBib3JkZXItY29sb3I6ICMwMDcyYjU7XG4gIGNvbG9yOiAjMDA3MmI1O1xuICBmb250LXdlaWdodDogYm9sZDtcbn1cbi5iYWRnZS5wcmltYXJ5LWNvbnRhaW5lZCB7XG4gIGJhY2tncm91bmQtY29sb3I6ICMwMDcyYjU7XG4gIGNvbG9yOiAjZmZmZmZmO1xufVxuLmJhZGdlLmNyZWF0b3JzLWJhZGdlIHtcbiAgYmFja2dyb3VuZC1jb2xvcjogIzY5Njk2OTtcbiAgY29sb3I6ICNmZmZmZmY7XG59IiwiLy8gJGJsdWU6ICMxOTBlOGY7XHJcbiRibHVlOiAjMDA3MmI1O1xyXG4vLyAkYmx1ZTogI0E4QjEwRTtcclxuLy8gJHBhc3RlbC1ibHVlOiAjQThCMTBFO1xyXG4kcGFzdGVsLWJsdWU6ICMwMDcyYjU7XHJcbiRvcmFuZ2U6ICNmZjk4MDA7XHJcbiRwYXN0ZWwtb3JhbmdlOiAjRkZCODREO1xyXG4kd2hpdGU6ICNmZmZmZmY7XHJcbiRncmF5OiAjYjRiNGI0O1xyXG4kbm9ybWFsOiAjNjk2OTY5O1xyXG4kYmxhY2s6IGRhcmtlbigkbm9ybWFsLCA3NSUpO1xyXG5cclxuJHByaW1hcnk6ICRibHVlO1xyXG4kc2Vjb25kYXJ5OiAkb3JhbmdlO1xyXG5cclxuJHRoZW1lLWNvbG9ycyA6IChcclxuICBcInNlY29uZGFyeVwiOiAgJHNlY29uZGFyeSxcclxuICBcIm5vcm1hbFwiOiAkbm9ybWFsLFxyXG4gIFwicGFzdGVsLWJsdWVcIjogJHBhc3RlbC1ibHVlLFxyXG4gIFwicGFzdGVsLW9yYW5nZVwiOiAkcGFzdGVsLW9yYW5nZVxyXG4pO1xyXG5cclxuJGdyaWQtYnJlYWtwb2ludHM6IChcclxuICB4czogMCxcclxuICBzbTogNTc2cHgsXHJcbiAgbWQ6IDc2OHB4LFxyXG4gIGxnOiA5OTJweCxcclxuICB4bDogMTIwMHB4XHJcbik7XHJcblxyXG4kY29udGFpbmVyLW1heC13aWR0aHM6IChcclxuICBzbTogNzY4cHgsXHJcbiAgbWQ6IDk1OXB4LFxyXG4gIGxnOiA5NjBweCxcclxuICB4bDogMTIwMHB4XHJcbik7XHJcblxyXG4kaW5wdXQtYm9yZGVyLXNpemU6IDFweDtcclxuJGJvcmRlci1zaXplOiAycHg7Il19 */\"","module.exports = \".select-dropdown-menu {\\n overflow-x: hidden;\\n}\\n.select-dropdown-menu .search {\\n display: -webkit-box;\\n display: flex;\\n padding: 8px 8px 8px 1.5rem;\\n width: 100%;\\n color: #696969;\\n}\\n.select-dropdown-menu input {\\n margin: 0;\\n margin-right: 8px;\\n padding: 0;\\n padding-bottom: 8px;\\n outline: none !important;\\n border: none;\\n border-radius: 0px;\\n border-bottom: 1px solid #696969;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL2FzeW5jLXNlbGVjdC9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFxjb21wb25lbnRzXFxhc3luYy1zZWxlY3RcXGFzeW5jLXNlbGVjdC5jb21wb25lbnQuc2NzcyIsInNyYy9jb21wb25lbnRzL2FzeW5jLXNlbGVjdC9hc3luYy1zZWxlY3QuY29tcG9uZW50LnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7RUFDRSxrQkFBQTtBQ0RGO0FER0U7RUFDRSxvQkFBQTtFQUFBLGFBQUE7RUFDQSwyQkFBQTtFQUNBLFdBQUE7RUFDQSxjQUFBO0FDREo7QURJRTtFQUNFLFNBQUE7RUFDQSxpQkFBQTtFQUNBLFVBQUE7RUFDQSxtQkFBQTtFQUNBLHdCQUFBO0VBQ0EsWUFBQTtFQUNBLGtCQUFBO0VBQ0EsZ0NBQUE7QUNGSiIsImZpbGUiOiJzcmMvY29tcG9uZW50cy9hc3luYy1zZWxlY3QvYXN5bmMtc2VsZWN0LmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiQGltcG9ydCAnLi4vLi4vdmFyaWFibGVzJztcclxuXHJcbi5zZWxlY3QtZHJvcGRvd24tbWVudSB7XHJcbiAgb3ZlcmZsb3cteDogaGlkZGVuO1xyXG5cclxuICAuc2VhcmNoIHtcclxuICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICBwYWRkaW5nOiA4cHggOHB4IDhweCAxLjVyZW07XHJcbiAgICB3aWR0aDogMTAwJTtcclxuICAgIGNvbG9yOiAkbm9ybWFsO1xyXG4gIH1cclxuXHJcbiAgaW5wdXQge1xyXG4gICAgbWFyZ2luOiAwO1xyXG4gICAgbWFyZ2luLXJpZ2h0OiA4cHg7XHJcbiAgICBwYWRkaW5nOiAwO1xyXG4gICAgcGFkZGluZy1ib3R0b206IDhweDtcclxuICAgIG91dGxpbmU6IG5vbmUgIWltcG9ydGFudDtcclxuICAgIGJvcmRlcjogbm9uZTtcclxuICAgIGJvcmRlci1yYWRpdXM6IDBweDtcclxuICAgIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAkbm9ybWFsO1xyXG4gIH1cclxufSIsIi5zZWxlY3QtZHJvcGRvd24tbWVudSB7XG4gIG92ZXJmbG93LXg6IGhpZGRlbjtcbn1cbi5zZWxlY3QtZHJvcGRvd24tbWVudSAuc2VhcmNoIHtcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogOHB4IDhweCA4cHggMS41cmVtO1xuICB3aWR0aDogMTAwJTtcbiAgY29sb3I6ICM2OTY5Njk7XG59XG4uc2VsZWN0LWRyb3Bkb3duLW1lbnUgaW5wdXQge1xuICBtYXJnaW46IDA7XG4gIG1hcmdpbi1yaWdodDogOHB4O1xuICBwYWRkaW5nOiAwO1xuICBwYWRkaW5nLWJvdHRvbTogOHB4O1xuICBvdXRsaW5lOiBub25lICFpbXBvcnRhbnQ7XG4gIGJvcmRlcjogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMHB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgIzY5Njk2OTtcbn0iXX0= */\"","import { Component, OnInit, ViewChild, Input, ContentChild, TemplateRef, ElementRef, OnChanges, SimpleChanges, Output, EventEmitter, ChangeDetectorRef } from \"@angular/core\";\r\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { NgbDropdown } from '@ng-bootstrap/ng-bootstrap';\r\nimport { of, merge } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, tap, switchMap } from 'rxjs/operators';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\nimport { faAngleDown, faSpinner, faSearch } from '@fortawesome/free-solid-svg-icons';\r\nimport { parseScrollEvent, ScrollType } from 'src/infrastructure/utils';\r\nimport { BaseNomenclature } from './models/base-nomenclature';\r\nimport { BaseFilter } from './models/base-filter';\r\nimport { TranslateService, LangChangeEvent } from '@ngx-translate/core';\r\n\r\n\r\n@Component({\r\n selector: 'ab-async-select',\r\n templateUrl: 'async-select.component.html',\r\n styleUrls: ['async-select.component.scss', '../select/select.component.scss'],\r\n providers: [\r\n {\r\n provide: NG_VALUE_ACCESSOR,\r\n useExisting: AsyncSelectComponent,\r\n multi: true\r\n }\r\n ]\r\n})\r\nexport class AsyncSelectComponent implements ControlValueAccessor, OnInit, OnChanges {\r\n constructor(\r\n private http: HttpClient,\r\n private config: Configuration,\r\n private translate: TranslateService\r\n ) { }\r\n\r\n @Input()\r\n restUrl: string;\r\n\r\n @Input()\r\n placeholder: string;\r\n\r\n @Output()\r\n modelChange: EventEmitter = new EventEmitter();\r\n\r\n @ContentChild('dropdownItemTemplate', { static: true })\r\n dropdownItemTemplate: TemplateRef;\r\n\r\n @ContentChild('selectedItemTemplate', { static: true })\r\n selectedItemTemplate: TemplateRef;\r\n\r\n @ViewChild('dropdown', { static: true })\r\n dropdown: NgbDropdown;\r\n\r\n @ViewChild('dropdownMenu', { static: true })\r\n dropdownMenu: ElementRef;\r\n\r\n searchControl = new FormControl(\"\");\r\n loadMore$ = new EventEmitter();\r\n\r\n search$ = merge(\r\n this.searchControl.valueChanges.pipe(\r\n distinctUntilChanged()\r\n ),\r\n this.loadMore$,\r\n ).pipe(\r\n debounceTime(300),\r\n switchMap(value => {\r\n if (typeof value === 'boolean')\r\n return of({\r\n textFilter: this.searchControl.value,\r\n limit: this.limit,\r\n offset: this.offset,\r\n replaceExisting: false\r\n });\r\n else\r\n return of({\r\n textFilter: value,\r\n limit: this.limit,\r\n offset: 0,\r\n replaceExisting: true\r\n });\r\n })\r\n );\r\n\r\n id: number;\r\n displayValue: string = null;\r\n nomenclature: T;\r\n isOpen: boolean;\r\n collection: T[] = [];\r\n loading = false;\r\n initialLoad = false;\r\n formControlChangeHandler: any;\r\n\r\n faAngleDown = faAngleDown;\r\n faSpinner = faSpinner;\r\n faSearch = faSearch;\r\n\r\n limit = 25;\r\n offset = 0;\r\n\r\n ngOnInit(): void {\r\n this.dropdown.openChange\r\n .subscribe((isOpen: boolean) => {\r\n this.isOpen = isOpen;\r\n this.searchControl.setValue('');\r\n if (this.isOpen && this.initialLoad) {\r\n this.getFiltered();\r\n this.initialLoad = true;\r\n }\r\n });\r\n\r\n this.translate.onLangChange.subscribe((event: LangChangeEvent) => this.displayValue = this.getNomenclatureValue())\r\n this.search$.subscribe(filter => this.getFiltered(filter));\r\n }\r\n\r\n ngOnChanges(changes: SimpleChanges) {\r\n if (changes['restUrl'] && changes['restUrl'].previousValue)\r\n this.getFiltered();\r\n }\r\n\r\n registerOnChange(fn: any): void {\r\n this.formControlChangeHandler = fn;\r\n }\r\n\r\n registerOnTouched(fn: any): void { }\r\n\r\n writeValue(id: number): void {\r\n this.id = id;\r\n this.loading = true;\r\n this.getNomenclature(id)\r\n .subscribe(nomenclature => {\r\n this.nomenclature = nomenclature;\r\n this.displayValue = this.getNomenclatureValue();\r\n this.modelChange.emit(this.nomenclature);\r\n this.loading = false;\r\n }, _ => this.loading = false);\r\n }\r\n\r\n getFiltered(filter?: BaseFilter) {\r\n if (!filter)\r\n filter = new BaseFilter();\r\n\r\n this.loading = true;\r\n this.http\r\n .get(`${this.config.restUrl}/${this.restUrl}?textFilter=${filter.textFilter}&limit=${filter.limit}&offset=${filter.offset}`)\r\n .subscribe(items => {\r\n if (filter.replaceExisting)\r\n this.collection = items;\r\n else\r\n this.collection.push(...items);\r\n this.loading = false;\r\n }, _ => this.loading = false);\r\n }\r\n\r\n getNomenclature(id: number) {\r\n if (!id)\r\n return of(null);\r\n\r\n let item = this.collection.find(e => e.id == id);\r\n\r\n if (item)\r\n return of(item);\r\n else\r\n return this.http.get(`${this.config.restUrl}/${this.restUrl}/${id}`);\r\n }\r\n\r\n getNomenclatureValue() {\r\n if (this.nomenclature == null)\r\n return null;\r\n else if (this.translate.currentLang === 'en')\r\n return this.nomenclature.nameEn;\r\n else\r\n return this.nomenclature.name;\r\n }\r\n\r\n selectItem(item: T) {\r\n this.id = item.id;\r\n this.nomenclature = item;\r\n this.displayValue = this.getNomenclatureValue();\r\n this.modelChange.emit(this.nomenclature);\r\n\r\n if (this.formControlChangeHandler)\r\n this.formControlChangeHandler(this.id);\r\n }\r\n\r\n handleScroll(event: WheelEvent) {\r\n var eventType = parseScrollEvent(event, this.dropdownMenu.nativeElement);\r\n\r\n if (eventType == ScrollType.bottom) {\r\n this.offset = this.collection.length;\r\n this.loadMore$.emit(true);\r\n }\r\n\r\n if (eventType != ScrollType.middle)\r\n event.preventDefault();\r\n }\r\n}","export class BaseFilter {\r\n textFilter: string = '';\r\n limit: number = 25;\r\n offset: number = 0;\r\n replaceExisting: boolean = true;\r\n}","module.exports = \".collapse-control {\\n font-weight: normal;\\n margin-top: 8px;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL2NvbGxhcHNhYmxlLXRleHQvQzpcXFByb2plY3RzXFxvcGVuc2NpZW5jZVxcUG9ydGFsLldlYkFwcGxpY2F0aW9uL3NyY1xcY29tcG9uZW50c1xcY29sbGFwc2FibGUtdGV4dFxcY29sbGFwc2FibGUtdGV4dC5jb21wb25lbnQuc2NzcyIsInNyYy9jb21wb25lbnRzL2NvbGxhcHNhYmxlLXRleHQvY29sbGFwc2FibGUtdGV4dC5jb21wb25lbnQuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQTtFQUNFLG1CQUFBO0VBQ0EsZUFBQTtBQ0FGIiwiZmlsZSI6InNyYy9jb21wb25lbnRzL2NvbGxhcHNhYmxlLXRleHQvY29sbGFwc2FibGUtdGV4dC5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIlxyXG4uY29sbGFwc2UtY29udHJvbCB7XHJcbiAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcclxuICBtYXJnaW4tdG9wOiA4cHg7XHJcbn0iLCIuY29sbGFwc2UtY29udHJvbCB7XG4gIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gIG1hcmdpbi10b3A6IDhweDtcbn0iXX0= */\"","import { Component, Input } from \"@angular/core\";\r\nimport { faAngleRight, faChevronRight } from '@fortawesome/free-solid-svg-icons';\r\n\r\n@Component({\r\n selector: 'ab-collapsable-text',\r\n templateUrl: 'collapsable-text.component.html',\r\n styleUrls: ['collapsable-text.component.scss']\r\n})\r\nexport class CollapsableTextComponent {\r\n @Input()\r\n text: string = '';\r\n\r\n isCollapsed = false;\r\n showMoreIcon = faAngleRight;\r\n}","import { NgModule } from \"@angular/core\";\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { NgBootstrapModule } from 'src/infrastructure/ng-bootstrap.module';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\r\n\r\nimport { SelectComponent } from './select/select.component';\r\nimport { AsyncSelectComponent } from './async-select/async-select.component';\r\nimport { CollapsableTextComponent } from './collapsable-text/collapsable-text.component';\r\nimport { LoadingIndicatorComponent } from './loading-indicator/loading-indicator.component';\r\nimport { PaginatorComponent } from './paginator/paginator.component';\r\nimport { LanguageSelectorComponent } from './language-selector/language-selector.component';\r\nimport { LightbulbIcon } from './icons/lightbulb.icon';\r\nimport { ShowMoreComponent } from './show-more/show-more.component';\r\nimport { DrawerComponent } from './drawer/drawer.component';\r\nimport { ForeignNameSelectorComponent } from './foreign-name-selector/foreign-name-selector.component';\r\nimport { GlobeIcon } from './icons/globe.icon';\r\nimport { LinkOrTextComponent } from './link-or-text/link-or-text.component';\r\nimport { LoadingSectionComponent } from \"./loading-section/loading-section.component\";\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n FormsModule,\r\n ReactiveFormsModule,\r\n NgBootstrapModule,\r\n TranslateModule,\r\n FontAwesomeModule\r\n ],\r\n declarations: [\r\n SelectComponent,\r\n AsyncSelectComponent,\r\n CollapsableTextComponent,\r\n LoadingIndicatorComponent,\r\n PaginatorComponent,\r\n LanguageSelectorComponent,\r\n LightbulbIcon,\r\n GlobeIcon,\r\n ShowMoreComponent,\r\n DrawerComponent,\r\n ForeignNameSelectorComponent,\r\n LinkOrTextComponent,\r\n LoadingSectionComponent\r\n ],\r\n exports: [\r\n SelectComponent,\r\n AsyncSelectComponent,\r\n CollapsableTextComponent,\r\n LoadingIndicatorComponent,\r\n PaginatorComponent,\r\n LanguageSelectorComponent,\r\n LightbulbIcon,\r\n GlobeIcon,\r\n ShowMoreComponent,\r\n DrawerComponent,\r\n ForeignNameSelectorComponent,\r\n LinkOrTextComponent,\r\n LoadingSectionComponent\r\n ]\r\n})\r\nexport class ComponentsModule { }","module.exports = \".backdrop {\\n position: fixed;\\n top: 0;\\n bottom: 0;\\n left: 0;\\n right: 0;\\n z-index: 9;\\n background-color: rgba(0, 0, 0, 0.507);\\n opacity: 0.8;\\n display: none;\\n}\\n.backdrop.open {\\n display: block;\\n}\\n.drawer-root {\\n position: fixed;\\n top: 0;\\n bottom: 0;\\n z-index: 10;\\n background-color: #b5e4ff;\\n padding: 16px;\\n -webkit-transition: left 0.2s ease-out;\\n transition: left 0.2s ease-out;\\n overflow-y: auto;\\n}\\n.drawer-root::-webkit-scrollbar {\\n width: 0.5em;\\n height: 0.5em;\\n}\\n.drawer-root::-webkit-scrollbar-thumb {\\n background: darkgray;\\n}\\n.drawer-root::-webkit-scrollbar-track {\\n background: #ffffff;\\n}\\n.drawer-root body {\\n scrollbar-face-color: darkgray;\\n scrollbar-track-color: #ffffff;\\n}\\n.drawer-root.open {\\n left: 0;\\n}\\n.drawer-root {\\n left: -80%;\\n width: 80%;\\n}\\n@media (min-width: 576px) {\\n .drawer-root {\\n left: -320px;\\n width: 320px;\\n }\\n}\\n@media (min-width: 768px) {\\n .drawer-root {\\n left: -320px;\\n width: 320px;\\n }\\n}\\n@media (min-width: 992px) {\\n .drawer-root {\\n left: -320px;\\n width: 320px;\\n }\\n}\\n@media (min-width: 1200px) {\\n .drawer-root {\\n left: -450px;\\n width: 450px;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/components/drawer/C:\\Projects\\openscience\\Portal.WebApplication/src\\components\\drawer\\drawer.component.scss","src/components/drawer/drawer.component.scss","src/components/drawer/C:\\Projects\\openscience\\Portal.WebApplication/src\\mixins.scss","src/components/drawer/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/components/drawer/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAWA;EACE,eAAA;EACA,MAAA;EACA,SAAA;EACA,OAAA;EACA,QAAA;EACA,UAAA;EACA,sCAAA;EACA,YAAA;EACA,aAAA;ACVF;ADYE;EACE,cAAA;ACVJ;ADcA;EACE,eAAA;EACA,MAAA;EACA,SAAA;EACA,WAAA;EACA,yBAAA;EACA,aAAA;EACA,sCAAA;EAAA,8BAAA;EACA,gBAAA;ACXF;ACPE;EACI,YFkBgB;EEjBhB,aFiBgB;ACRtB;ACNE;EACI,oBFasB;ACL5B;ACLE;EACI,mBCpBE;AF2BR;ACHE;EACE,8BFIwB;EEHxB,8BC1BI;AF+BR;ADAE;EACE,OAAA;ACEJ;ADII;EACE,UAAA;EACA,UA5CU;AC2ChB;AGcI;EJfA;IACE,YAAA;IACA,YA5CU;ECiDd;AACF;AGOI;EJfA;IACE,YAAA;IACA,YA5CU;ECuDd;AACF;AGCI;EJfA;IACE,YAAA;IACA,YA5CU;EC6Dd;AACF;AGLI;EJfA;IACE,YAAA;IACA,YA5CU;ECmEd;AACF","file":"src/components/drawer/drawer.component.scss","sourcesContent":["@import \"../../variables\";\r\n@import \"../../mixins\";\r\n\r\n$drawer-widths: (\r\n  xs: 80%,\r\n  sm: 320px,\r\n  md: 320px,\r\n  lg: 320px,\r\n  xl: 450px\r\n);\r\n\r\n.backdrop {\r\n  position: fixed;\r\n  top: 0;\r\n  bottom: 0;\r\n  left: 0;\r\n  right: 0;\r\n  z-index: 9;\r\n  background-color: rgba(0, 0, 0, 0.507);\r\n  opacity: .8;\r\n  display: none;\r\n\r\n  &.open {\r\n    display: block;\r\n  }\r\n}\r\n\r\n.drawer-root {\r\n  position: fixed;\r\n  top: 0;\r\n  bottom: 0;\r\n  z-index: 10;\r\n  background-color: lighten($color: $pastel-blue, $amount: 50%);\r\n  padding: 16px;\r\n  transition: left .2s ease-out;\r\n  overflow-y: auto;\r\n  @include scrollbars(.5em, lighten($normal, 25%), $white);\r\n\r\n  &.open {\r\n    left: 0;\r\n  }\r\n}\r\n\r\n@each $breakpoint, $width in $drawer-widths {\r\n  @include media-breakpoint-up($breakpoint) {\r\n    .drawer-root {\r\n      left: -$width;\r\n      width: $width;\r\n    }\r\n  }\r\n}",".backdrop {\n  position: fixed;\n  top: 0;\n  bottom: 0;\n  left: 0;\n  right: 0;\n  z-index: 9;\n  background-color: rgba(0, 0, 0, 0.507);\n  opacity: 0.8;\n  display: none;\n}\n.backdrop.open {\n  display: block;\n}\n\n.drawer-root {\n  position: fixed;\n  top: 0;\n  bottom: 0;\n  z-index: 10;\n  background-color: #b5e4ff;\n  padding: 16px;\n  transition: left 0.2s ease-out;\n  overflow-y: auto;\n}\n.drawer-root::-webkit-scrollbar {\n  width: 0.5em;\n  height: 0.5em;\n}\n.drawer-root::-webkit-scrollbar-thumb {\n  background: darkgray;\n}\n.drawer-root::-webkit-scrollbar-track {\n  background: #ffffff;\n}\n.drawer-root body {\n  scrollbar-face-color: darkgray;\n  scrollbar-track-color: #ffffff;\n}\n.drawer-root.open {\n  left: 0;\n}\n\n.drawer-root {\n  left: -80%;\n  width: 80%;\n}\n\n@media (min-width: 576px) {\n  .drawer-root {\n    left: -320px;\n    width: 320px;\n  }\n}\n@media (min-width: 768px) {\n  .drawer-root {\n    left: -320px;\n    width: 320px;\n  }\n}\n@media (min-width: 992px) {\n  .drawer-root {\n    left: -320px;\n    width: 320px;\n  }\n}\n@media (min-width: 1200px) {\n  .drawer-root {\n    left: -450px;\n    width: 450px;\n  }\n}","@import \"node_modules/bootstrap/scss/mixins/_breakpoints.scss\";\r\n@import \"variables\";\r\n\r\n/// Mixin to customize scrollbars\r\n/// Beware, this does not work in all browsers\r\n/// @author Hugo Giraudel\r\n/// @param {Length} $size - Horizontal scrollbar's height and vertical scrollbar's width\r\n/// @param {Color} $foreground-color - Scrollbar's color\r\n/// @param {Color} $background-color [mix($foreground-color, white, 50%)] - Scrollbar's color\r\n/// @example scss - Scrollbar styling\r\n///   @include scrollbars(.5em, slategray);\r\n@mixin scrollbars(\r\n  $size, \r\n  $foreground-color, \r\n  $background-color: mix($foreground-color, white,  50%)\r\n) {\r\n  // For Google Chrome\r\n  &::-webkit-scrollbar {\r\n      width:  $size;\r\n      height: $size;\r\n  }\r\n\r\n  &::-webkit-scrollbar-thumb {\r\n      background: $foreground-color;\r\n  }\r\n\r\n  &::-webkit-scrollbar-track {\r\n      background: $background-color;\r\n  }\r\n\r\n  // For Internet Explorer\r\n  & body {\r\n    scrollbar-face-color: $foreground-color;\r\n    scrollbar-track-color: $background-color;\r\n  }\r\n}\r\n\r\n@mixin formToggles(\r\n  $fontSize:16px, \r\n  $lineHeight: 1.5rem, \r\n  $border:2, \r\n  $bg: $primary, \r\n  $fg: #FFFFFF, \r\n  $disable: #CCCCCC\r\n) {\r\n  // strip the units (expecting a px value, but remove so we've just got an int)\r\n  $baseFont: ($fontSize) / ($fontSize * 0 + 1);\r\n  // ensure our base is a rem val\r\n  $base: ($lineHeight) / ($lineHeight * 0 + 1) * 1rem;\r\n  // get our borderwidth in rems\r\n  $borderWidth: (($border) / ($border * 0 + 1) / $baseFont) * 1rem;\r\n  .toggles {\r\n    label {\r\n      line-height: $base;\r\n      position: relative;\r\n      display: inline-block;\r\n      padding-left: $base;\r\n      width: 100%;\r\n      margin-bottom: 0;\r\n      &:before,\r\n      &:after {\r\n        box-sizing: border-box;\r\n        line-height: $base;\r\n        content: ' ';\r\n        display: block;\r\n        position: absolute;\r\n        top: $base/4.1;\r\n        left: 0;\r\n        width: $base/2;\r\n        height: $base/2;\r\n        border-radius: 100%;\r\n      }\r\n      &:before {\r\n        width: ($base/2)+$borderWidth*2;\r\n        height: ($base/2)+$borderWidth*2;\r\n        margin: -$borderWidth;\r\n        transition: background .36s;\r\n      }\r\n      /* Radio's setup */\r\n      &:after {\r\n        border: $borderWidth solid $fg;\r\n        transform: scale(0);\r\n        transition: background .12s, transform .16s;\r\n      }\r\n      /* The radio button background */\r\n      &:before {\r\n        border: $borderWidth solid $bg;\r\n      }\r\n      /* Checkbox setup */\r\n      &.checkbox:before,\r\n      &.checkbox:after {\r\n        border-radius: 0;\r\n      }\r\n      /* the check box background */\r\n      &.checkbox:before {\r\n        width: ($base/2)+$borderWidth*2;\r\n        height: ($base/2)+$borderWidth*2;\r\n        border-radius: 0;\r\n      }\r\n      /* Label hover state */\r\n      &:hover {\r\n        color: $bg;\r\n      }\r\n      /* Create an alternative stlye for switches */\r\n      &.switch {\r\n        padding-left: $base * 1.5;\r\n        display: block;\r\n        &:before {\r\n          width: ($base)+$borderWidth*2;\r\n          height: ($base/2)+$borderWidth*2;\r\n          border: $borderWidth solid $disable;\r\n        }\r\n        &:After {\r\n          transform: scale(1);\r\n          background: $disable;\r\n        }\r\n        &.round:before {\r\n          border-radius: 40%/80%;\r\n        }\r\n        &.round:after {\r\n          border-radius: 100%;\r\n        }\r\n        &.material:before {\r\n          top: $base/4+$borderWidth*2;\r\n          width: ($base)+$borderWidth*2;\r\n          height: ($base/2)-$borderWidth*2;\r\n          border-radius: 20%/40%;\r\n          border: none;\r\n          background: lighten($disable, 14%);\r\n        }\r\n        &.material:after {\r\n          top: $base/4-$borderWidth;\r\n          left: -$borderWidth;\r\n          border: none;\r\n          border-radius: 100%;\r\n          width: $base/2+$borderWidth*2;\r\n          height: $base/2+$borderWidth*2;\r\n        }\r\n      }\r\n    }\r\n    /* Hide the input elements and use there psuedo elements */\r\n    input[type=\"radio\"] {\r\n      display: none;\r\n      &:checked + label:after {\r\n        transform: scale(1);\r\n        background: $bg;\r\n      }\r\n    }\r\n    /* hide the input element */\r\n    input[type=\"checkbox\"] {\r\n      display: none;\r\n      /* style active state psuedo element */\r\n      &:checked + label:after {\r\n        content: '\\2713';\r\n        display: inline-block;\r\n        background: #fff;\r\n        color:$bg;\r\n        line-height: $base/2+$borderWidth;\r\n        font-size: $base/2;\r\n        font-weight: bold;\r\n        text-align: center;\r\n        transform: scale(1);\r\n        border: none;\r\n      }\r\n    }\r\n    // switch active states\r\n    input[type=\"radio\"],\r\n    input[type=\"checkbox\"] {\r\n      /* Add additional adjustments for switch style */\r\n      &:checked + label.switch {\r\n        &:before {\r\n          border-color: $bg;\r\n        }\r\n        &.material:before {\r\n          background: lighten($primary, 4%);\r\n        }\r\n      }\r\n      &:checked + label.switch {\r\n        &:after {\r\n          // no 3d, to support ie9+\r\n          transform: translateX($base*0.5);\r\n          border: $borderWidth solid $fg;\r\n          content: '';\r\n        }\r\n        &.material:after {\r\n          background: $primary;\r\n          border: none;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnInit, ElementRef, ViewChild, Input } from '@angular/core';\r\nimport { faTimes } from '@fortawesome/free-solid-svg-icons';\r\nimport { parseScrollEvent, ScrollType } from 'src/infrastructure/utils';\r\n\r\n@Component({\r\n selector: 'app-drawer',\r\n templateUrl: './drawer.component.html',\r\n styleUrls: ['./drawer.component.scss']\r\n})\r\nexport class DrawerComponent {\r\n isOpen = false;\r\n faTimes = faTimes;\r\n\r\n preventScroll(event) {\r\n event.preventDefault();\r\n }\r\n\r\n @ViewChild('drawer', { static: false }) drawer: ElementRef;\r\n\r\n limitScroll(event: WheelEvent) {\r\n var eventType = parseScrollEvent(event, this.drawer.nativeElement);\r\n if (eventType != ScrollType.middle)\r\n event.preventDefault();\r\n }\r\n}\r\n","import { Component, Input, ContentChild, TemplateRef, ElementRef, ChangeDetectorRef, OnInit, OnDestroy } from \"@angular/core\";\r\nimport { TranslateService, LangChangeEvent } from '@ngx-translate/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\n@Component({\r\n selector: 'foreign-name-select',\r\n templateUrl: 'foreign-name-selector.component.html'\r\n})\r\nexport class ForeignNameSelectorComponent implements OnInit, OnDestroy {\r\n\r\n\r\n constructor(\r\n private translate: TranslateService,\r\n private changeDetector: ChangeDetectorRef\r\n ) {\r\n }\r\n\r\n @Input('model')\r\n model: T;\r\n\r\n @ContentChild('valueTemplate', { static: true })\r\n valueTemplate: TemplateRef = null;\r\n value = null;\r\n\r\n s: Subscription = null;\r\n\r\n ngOnInit() {\r\n this.s = this.translate.onLangChange.subscribe((event: LangChangeEvent) => {\r\n this.selectValue(event.lang);\r\n this.changeDetector.detectChanges();\r\n });\r\n\r\n this.selectValue(this.translate.currentLang);\r\n }\r\n\r\n selectValue(lang: string) {\r\n this.value = lang === \"en\" ? this.model.nameEn || this.model.name || \"\" : this.model.name || \"\";\r\n }\r\n\r\n ngOnDestroy() {\r\n if (this.s)\r\n this.s.unsubscribe();\r\n }\r\n}","import { Component } from \"@angular/core\";\r\n\r\n@Component({\r\n selector: 'globe-icon',\r\n template: `\r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n`\r\n})\r\nexport class GlobeIcon {\r\n\r\n}","import { Component, OnInit, Input, OnDestroy } from \"@angular/core\";\r\nimport * as KUTE from 'kute.js/kute.js';\r\nimport 'kute.js/kute-svg.js';\r\n\r\n@Component({\r\n selector: 'lightbulb-icon',\r\n template: `\r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n`,\r\n styles: [`\r\n .cls-1 {\r\n fill: none;\r\n stroke: currentColor;\r\n stroke-miterlimit: 10;\r\n stroke-width: 10px;\r\n }\r\n \r\n .cls-2 {\r\n fill: currentColor;\r\n }\r\n \r\n .cls-3 {\r\n fill: currentColor;\r\n }\r\n `]\r\n})\r\nexport class LightbulbIcon implements OnInit, OnDestroy {\r\n @Input()\r\n animate: boolean = undefined;\r\n\r\n @Input()\r\n width: string = \"50px\";\r\n\r\n @Input()\r\n height: string = \"50px\";\r\n\r\n animationOptions = {\r\n offset: 100,\r\n duration: 6 * 100 * 2,\r\n repeat: 1000,\r\n easing: 'linear'\r\n };\r\n\r\n animation: any;\r\n\r\n ngOnInit() {\r\n if (this.animate !== undefined) {\r\n this.animation = KUTE.allFromTo('.cls-3', { color: '#ff931e' }, { color: '#3a3632' }, this.animationOptions);\r\n this.animation.start();\r\n }\r\n\r\n }\r\n\r\n ngOnDestroy(): void {\r\n if (this.animation)\r\n this.animation.stop();\r\n }\r\n}","module.exports = \".root {\\n border-left: 1px solid black;\\n padding: 8px 16px;\\n padding-left: 32px;\\n margin-left: 16px;\\n}\\n.root .lang {\\n margin-left: 8px;\\n font-weight: normal;\\n}\\n@media (max-width: 1199.98px) {\\n .root {\\n border-left-color: transparent;\\n padding-left: 0px;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL2xhbmd1YWdlLXNlbGVjdG9yL0M6XFxQcm9qZWN0c1xcb3BlbnNjaWVuY2VcXFBvcnRhbC5XZWJBcHBsaWNhdGlvbi9zcmNcXGNvbXBvbmVudHNcXGxhbmd1YWdlLXNlbGVjdG9yXFxsYW5ndWFnZS1zZWxlY3Rvci5jb21wb25lbnQuc2NzcyIsInNyYy9jb21wb25lbnRzL2xhbmd1YWdlLXNlbGVjdG9yL2xhbmd1YWdlLXNlbGVjdG9yLmNvbXBvbmVudC5zY3NzIiwic3JjL2NvbXBvbmVudHMvbGFuZ3VhZ2Utc2VsZWN0b3IvQzpcXFByb2plY3RzXFxvcGVuc2NpZW5jZVxcUG9ydGFsLldlYkFwcGxpY2F0aW9uL25vZGVfbW9kdWxlc1xcYm9vdHN0cmFwXFxzY3NzXFxtaXhpbnNcXF9icmVha3BvaW50cy5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBO0VBQ0MsNEJBQUE7RUFDQSxpQkFBQTtFQUNBLGtCQUFBO0VBQ0EsaUJBQUE7QUNGRDtBRFFDO0VBQ0UsZ0JBQUE7RUFDQSxtQkFBQTtBQ05IO0FDZ0VJO0VGckRGO0lBQ0UsOEJBQUE7SUFDQSxpQkFBQTtFQ1BGO0FBQ0YiLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvbGFuZ3VhZ2Utc2VsZWN0b3IvbGFuZ3VhZ2Utc2VsZWN0b3IuY29tcG9uZW50LnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyJAaW1wb3J0ICcuLi8uLi92YXJpYWJsZXMnO1xyXG5AaW1wb3J0ICcuLi8uLi9taXhpbnMnO1xyXG5cclxuLnJvb3Qge1xyXG4gYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAkYmxhY2s7XHJcbiBwYWRkaW5nOiA4cHggMTZweDtcclxuIHBhZGRpbmctbGVmdDogMzJweDtcclxuIG1hcmdpbi1sZWZ0OiAxNnB4O1xyXG5cclxuLy8gIGZhLWljb24ge1xyXG4vLyAgICBjb2xvcjogJHByaW1hcnk7XHJcbi8vICB9XHJcblxyXG4gLmxhbmcge1xyXG4gICBtYXJnaW4tbGVmdDogOHB4O1xyXG4gICBmb250LXdlaWdodDogbm9ybWFsO1xyXG4gfVxyXG59XHJcblxyXG5AaW5jbHVkZSBtZWRpYS1icmVha3BvaW50LWRvd24oXCJsZ1wiKSB7XHJcbiAgLnJvb3Qge1xyXG4gICAgYm9yZGVyLWxlZnQtY29sb3I6IHRyYW5zcGFyZW50O1xyXG4gICAgcGFkZGluZy1sZWZ0OiAwcHg7XHJcbiAgfVxyXG59IiwiLnJvb3Qge1xuICBib3JkZXItbGVmdDogMXB4IHNvbGlkIGJsYWNrO1xuICBwYWRkaW5nOiA4cHggMTZweDtcbiAgcGFkZGluZy1sZWZ0OiAzMnB4O1xuICBtYXJnaW4tbGVmdDogMTZweDtcbn1cbi5yb290IC5sYW5nIHtcbiAgbWFyZ2luLWxlZnQ6IDhweDtcbiAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbn1cblxuQG1lZGlhIChtYXgtd2lkdGg6IDExOTkuOThweCkge1xuICAucm9vdCB7XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6IHRyYW5zcGFyZW50O1xuICAgIHBhZGRpbmctbGVmdDogMHB4O1xuICB9XG59IiwiLy8gQnJlYWtwb2ludCB2aWV3cG9ydCBzaXplcyBhbmQgbWVkaWEgcXVlcmllcy5cbi8vXG4vLyBCcmVha3BvaW50cyBhcmUgZGVmaW5lZCBhcyBhIG1hcCBvZiAobmFtZTogbWluaW11bSB3aWR0aCksIG9yZGVyIGZyb20gc21hbGwgdG8gbGFyZ2U6XG4vL1xuLy8gICAgKHhzOiAwLCBzbTogNTc2cHgsIG1kOiA3NjhweCwgbGc6IDk5MnB4LCB4bDogMTIwMHB4KVxuLy9cbi8vIFRoZSBtYXAgZGVmaW5lZCBpbiB0aGUgYCRncmlkLWJyZWFrcG9pbnRzYCBnbG9iYWwgdmFyaWFibGUgaXMgdXNlZCBhcyB0aGUgYCRicmVha3BvaW50c2AgYXJndW1lbnQgYnkgZGVmYXVsdC5cblxuLy8gTmFtZSBvZiB0aGUgbmV4dCBicmVha3BvaW50LCBvciBudWxsIGZvciB0aGUgbGFzdCBicmVha3BvaW50LlxuLy9cbi8vICAgID4+IGJyZWFrcG9pbnQtbmV4dChzbSlcbi8vICAgIG1kXG4vLyAgICA+PiBicmVha3BvaW50LW5leHQoc20sICh4czogMCwgc206IDU3NnB4LCBtZDogNzY4cHgsIGxnOiA5OTJweCwgeGw6IDEyMDBweCkpXG4vLyAgICBtZFxuLy8gICAgPj4gYnJlYWtwb2ludC1uZXh0KHNtLCAkYnJlYWtwb2ludC1uYW1lczogKHhzIHNtIG1kIGxnIHhsKSlcbi8vICAgIG1kXG5AZnVuY3Rpb24gYnJlYWtwb2ludC1uZXh0KCRuYW1lLCAkYnJlYWtwb2ludHM6ICRncmlkLWJyZWFrcG9pbnRzLCAkYnJlYWtwb2ludC1uYW1lczogbWFwLWtleXMoJGJyZWFrcG9pbnRzKSkge1xuICAkbjogaW5kZXgoJGJyZWFrcG9pbnQtbmFtZXMsICRuYW1lKTtcbiAgQHJldHVybiBpZigkbiAhPSBudWxsIGFuZCAkbiA8IGxlbmd0aCgkYnJlYWtwb2ludC1uYW1lcyksIG50aCgkYnJlYWtwb2ludC1uYW1lcywgJG4gKyAxKSwgbnVsbCk7XG59XG5cbi8vIE1pbmltdW0gYnJlYWtwb2ludCB3aWR0aC4gTnVsbCBmb3IgdGhlIHNtYWxsZXN0IChmaXJzdCkgYnJlYWtwb2ludC5cbi8vXG4vLyAgICA+PiBicmVha3BvaW50LW1pbihzbSwgKHhzOiAwLCBzbTogNTc2cHgsIG1kOiA3NjhweCwgbGc6IDk5MnB4LCB4bDogMTIwMHB4KSlcbi8vICAgIDU3NnB4XG5AZnVuY3Rpb24gYnJlYWtwb2ludC1taW4oJG5hbWUsICRicmVha3BvaW50czogJGdyaWQtYnJlYWtwb2ludHMpIHtcbiAgJG1pbjogbWFwLWdldCgkYnJlYWtwb2ludHMsICRuYW1lKTtcbiAgQHJldHVybiBpZigkbWluICE9IDAsICRtaW4sIG51bGwpO1xufVxuXG4vLyBNYXhpbXVtIGJyZWFrcG9pbnQgd2lkdGguIE51bGwgZm9yIHRoZSBsYXJnZXN0IChsYXN0KSBicmVha3BvaW50LlxuLy8gVGhlIG1heGltdW0gdmFsdWUgaXMgY2FsY3VsYXRlZCBhcyB0aGUgbWluaW11bSBvZiB0aGUgbmV4dCBvbmUgbGVzcyAwLjAycHhcbi8vIHRvIHdvcmsgYXJvdW5kIHRoZSBsaW1pdGF0aW9ucyBvZiBgbWluLWAgYW5kIGBtYXgtYCBwcmVmaXhlcyBhbmQgdmlld3BvcnRzIHdpdGggZnJhY3Rpb25hbCB3aWR0aHMuXG4vLyBTZWUgaHR0cHM6Ly93d3cudzMub3JnL1RSL21lZGlhcXVlcmllcy00LyNtcS1taW4tbWF4XG4vLyBVc2VzIDAuMDJweCByYXRoZXIgdGhhbiAwLjAxcHggdG8gd29yayBhcm91bmQgYSBjdXJyZW50IHJvdW5kaW5nIGJ1ZyBpbiBTYWZhcmkuXG4vLyBTZWUgaHR0cHM6Ly9idWdzLndlYmtpdC5vcmcvc2hvd19idWcuY2dpP2lkPTE3ODI2MVxuLy9cbi8vICAgID4+IGJyZWFrcG9pbnQtbWF4KHNtLCAoeHM6IDAsIHNtOiA1NzZweCwgbWQ6IDc2OHB4LCBsZzogOTkycHgsIHhsOiAxMjAwcHgpKVxuLy8gICAgNzY3Ljk4cHhcbkBmdW5jdGlvbiBicmVha3BvaW50LW1heCgkbmFtZSwgJGJyZWFrcG9pbnRzOiAkZ3JpZC1icmVha3BvaW50cykge1xuICAkbmV4dDogYnJlYWtwb2ludC1uZXh0KCRuYW1lLCAkYnJlYWtwb2ludHMpO1xuICBAcmV0dXJuIGlmKCRuZXh0LCBicmVha3BvaW50LW1pbigkbmV4dCwgJGJyZWFrcG9pbnRzKSAtIC4wMiwgbnVsbCk7XG59XG5cbi8vIFJldHVybnMgYSBibGFuayBzdHJpbmcgaWYgc21hbGxlc3QgYnJlYWtwb2ludCwgb3RoZXJ3aXNlIHJldHVybnMgdGhlIG5hbWUgd2l0aCBhIGRhc2ggaW4gZnJvbnQuXG4vLyBVc2VmdWwgZm9yIG1ha2luZyByZXNwb25zaXZlIHV0aWxpdGllcy5cbi8vXG4vLyAgICA+PiBicmVha3BvaW50LWluZml4KHhzLCAoeHM6IDAsIHNtOiA1NzZweCwgbWQ6IDc2OHB4LCBsZzogOTkycHgsIHhsOiAxMjAwcHgpKVxuLy8gICAgXCJcIiAgKFJldHVybnMgYSBibGFuayBzdHJpbmcpXG4vLyAgICA+PiBicmVha3BvaW50LWluZml4KHNtLCAoeHM6IDAsIHNtOiA1NzZweCwgbWQ6IDc2OHB4LCBsZzogOTkycHgsIHhsOiAxMjAwcHgpKVxuLy8gICAgXCItc21cIlxuQGZ1bmN0aW9uIGJyZWFrcG9pbnQtaW5maXgoJG5hbWUsICRicmVha3BvaW50czogJGdyaWQtYnJlYWtwb2ludHMpIHtcbiAgQHJldHVybiBpZihicmVha3BvaW50LW1pbigkbmFtZSwgJGJyZWFrcG9pbnRzKSA9PSBudWxsLCBcIlwiLCBcIi0jeyRuYW1lfVwiKTtcbn1cblxuLy8gTWVkaWEgb2YgYXQgbGVhc3QgdGhlIG1pbmltdW0gYnJlYWtwb2ludCB3aWR0aC4gTm8gcXVlcnkgZm9yIHRoZSBzbWFsbGVzdCBicmVha3BvaW50LlxuLy8gTWFrZXMgdGhlIEBjb250ZW50IGFwcGx5IHRvIHRoZSBnaXZlbiBicmVha3BvaW50IGFuZCB3aWRlci5cbkBtaXhpbiBtZWRpYS1icmVha3BvaW50LXVwKCRuYW1lLCAkYnJlYWtwb2ludHM6ICRncmlkLWJyZWFrcG9pbnRzKSB7XG4gICRtaW46IGJyZWFrcG9pbnQtbWluKCRuYW1lLCAkYnJlYWtwb2ludHMpO1xuICBAaWYgJG1pbiB7XG4gICAgQG1lZGlhIChtaW4td2lkdGg6ICRtaW4pIHtcbiAgICAgIEBjb250ZW50O1xuICAgIH1cbiAgfSBAZWxzZSB7XG4gICAgQGNvbnRlbnQ7XG4gIH1cbn1cblxuLy8gTWVkaWEgb2YgYXQgbW9zdCB0aGUgbWF4aW11bSBicmVha3BvaW50IHdpZHRoLiBObyBxdWVyeSBmb3IgdGhlIGxhcmdlc3QgYnJlYWtwb2ludC5cbi8vIE1ha2VzIHRoZSBAY29udGVudCBhcHBseSB0byB0aGUgZ2l2ZW4gYnJlYWtwb2ludCBhbmQgbmFycm93ZXIuXG5AbWl4aW4gbWVkaWEtYnJlYWtwb2ludC1kb3duKCRuYW1lLCAkYnJlYWtwb2ludHM6ICRncmlkLWJyZWFrcG9pbnRzKSB7XG4gICRtYXg6IGJyZWFrcG9pbnQtbWF4KCRuYW1lLCAkYnJlYWtwb2ludHMpO1xuICBAaWYgJG1heCB7XG4gICAgQG1lZGlhIChtYXgtd2lkdGg6ICRtYXgpIHtcbiAgICAgIEBjb250ZW50O1xuICAgIH1cbiAgfSBAZWxzZSB7XG4gICAgQGNvbnRlbnQ7XG4gIH1cbn1cblxuLy8gTWVkaWEgdGhhdCBzcGFucyBtdWx0aXBsZSBicmVha3BvaW50IHdpZHRocy5cbi8vIE1ha2VzIHRoZSBAY29udGVudCBhcHBseSBiZXR3ZWVuIHRoZSBtaW4gYW5kIG1heCBicmVha3BvaW50c1xuQG1peGluIG1lZGlhLWJyZWFrcG9pbnQtYmV0d2VlbigkbG93ZXIsICR1cHBlciwgJGJyZWFrcG9pbnRzOiAkZ3JpZC1icmVha3BvaW50cykge1xuICAkbWluOiBicmVha3BvaW50LW1pbigkbG93ZXIsICRicmVha3BvaW50cyk7XG4gICRtYXg6IGJyZWFrcG9pbnQtbWF4KCR1cHBlciwgJGJyZWFrcG9pbnRzKTtcblxuICBAaWYgJG1pbiAhPSBudWxsIGFuZCAkbWF4ICE9IG51bGwge1xuICAgIEBtZWRpYSAobWluLXdpZHRoOiAkbWluKSBhbmQgKG1heC13aWR0aDogJG1heCkge1xuICAgICAgQGNvbnRlbnQ7XG4gICAgfVxuICB9IEBlbHNlIGlmICRtYXggPT0gbnVsbCB7XG4gICAgQGluY2x1ZGUgbWVkaWEtYnJlYWtwb2ludC11cCgkbG93ZXIsICRicmVha3BvaW50cykge1xuICAgICAgQGNvbnRlbnQ7XG4gICAgfVxuICB9IEBlbHNlIGlmICRtaW4gPT0gbnVsbCB7XG4gICAgQGluY2x1ZGUgbWVkaWEtYnJlYWtwb2ludC1kb3duKCR1cHBlciwgJGJyZWFrcG9pbnRzKSB7XG4gICAgICBAY29udGVudDtcbiAgICB9XG4gIH1cbn1cblxuLy8gTWVkaWEgYmV0d2VlbiB0aGUgYnJlYWtwb2ludCdzIG1pbmltdW0gYW5kIG1heGltdW0gd2lkdGhzLlxuLy8gTm8gbWluaW11bSBmb3IgdGhlIHNtYWxsZXN0IGJyZWFrcG9pbnQsIGFuZCBubyBtYXhpbXVtIGZvciB0aGUgbGFyZ2VzdCBvbmUuXG4vLyBNYWtlcyB0aGUgQGNvbnRlbnQgYXBwbHkgb25seSB0byB0aGUgZ2l2ZW4gYnJlYWtwb2ludCwgbm90IHZpZXdwb3J0cyBhbnkgd2lkZXIgb3IgbmFycm93ZXIuXG5AbWl4aW4gbWVkaWEtYnJlYWtwb2ludC1vbmx5KCRuYW1lLCAkYnJlYWtwb2ludHM6ICRncmlkLWJyZWFrcG9pbnRzKSB7XG4gICRtaW46IGJyZWFrcG9pbnQtbWluKCRuYW1lLCAkYnJlYWtwb2ludHMpO1xuICAkbWF4OiBicmVha3BvaW50LW1heCgkbmFtZSwgJGJyZWFrcG9pbnRzKTtcblxuICBAaWYgJG1pbiAhPSBudWxsIGFuZCAkbWF4ICE9IG51bGwge1xuICAgIEBtZWRpYSAobWluLXdpZHRoOiAkbWluKSBhbmQgKG1heC13aWR0aDogJG1heCkge1xuICAgICAgQGNvbnRlbnQ7XG4gICAgfVxuICB9IEBlbHNlIGlmICRtYXggPT0gbnVsbCB7XG4gICAgQGluY2x1ZGUgbWVkaWEtYnJlYWtwb2ludC11cCgkbmFtZSwgJGJyZWFrcG9pbnRzKSB7XG4gICAgICBAY29udGVudDtcbiAgICB9XG4gIH0gQGVsc2UgaWYgJG1pbiA9PSBudWxsIHtcbiAgICBAaW5jbHVkZSBtZWRpYS1icmVha3BvaW50LWRvd24oJG5hbWUsICRicmVha3BvaW50cykge1xuICAgICAgQGNvbnRlbnQ7XG4gICAgfVxuICB9XG59XG4iXX0= */\"","import { Component, OnInit } from \"@angular/core\";\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { faGlobe, faSpinner } from '@fortawesome/free-solid-svg-icons';\r\nimport { LoadingIndicatorService } from 'src/infrastructure/loading-indicator.service';\r\n\r\n@Component({\r\n selector: 'ab-language-selector',\r\n templateUrl: 'language-selector.component.html',\r\n styleUrls: ['language-selector.component.scss']\r\n})\r\nexport class LanguageSelectorComponent implements OnInit {\r\n constructor(\r\n private translateService: TranslateService,\r\n private loadingIndicator: LoadingIndicatorService\r\n ) { }\r\n\r\n languages = [\r\n { name: 'Български', language: 'en' },\r\n { name: 'English', language: 'bg' }\r\n ];\r\n\r\n loadingIcon = faSpinner;\r\n selected = this.languages.find(language => language.language == this.translateService.currentLang);\r\n loading = false;\r\n\r\n ngOnInit() {\r\n this.loadingIndicator.change$.subscribe(next => this.loading = next);\r\n this.translateService.onLangChange.subscribe(lang => this.selected = this.languages.find(language => language.language == lang.lang))\r\n }\r\n\r\n selectLanguage() {\r\n if (this.selected.language === 'en')\r\n this.selected = this.languages[1];\r\n else\r\n this.selected = this.languages[0];\r\n\r\n this.loadingIndicator.start();\r\n this.translateService.use(this.selected.language)\r\n .subscribe(_ => this.loadingIndicator.stop(), _ => this.loadingIndicator.stop());\r\n }\r\n}","module.exports = \".contain-text {\\n display: inline-block;\\n max-width: 35rem;\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n}\\n\\na {\\n font-weight: normal !important;\\n}\\n\\n@media (max-width: 1199.98px) {\\n .contain-text {\\n max-width: 20rem;\\n }\\n}\\n\\n@media (max-width: 767.98px) {\\n .contain-text {\\n max-width: 15rem;\\n }\\n}\\n\\n@media (max-width: 575.98px) {\\n .contain-text {\\n max-width: 10rem;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/components/link-or-text/C:\\Projects\\openscience\\Portal.WebApplication/src\\components\\link-or-text\\link-or-text.component.scss","src/components/link-or-text/link-or-text.component.scss","src/components/link-or-text/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAEA;EACI,qBAAA;EACA,gBAAA;EACA,gBAAA;EACA,uBAAA;EACA,mBAAA;ACDJ;;ADIA;EACI,8BAAA;ACDJ;;AC+DI;EF1DA;IACI,gBAAA;ECDN;AACF;;ACyDI;EFpDA;IACI,gBAAA;ECFN;AACF;;ACoDI;EF9CA;IACI,gBAAA;ECHN;AACF","file":"src/components/link-or-text/link-or-text.component.scss","sourcesContent":["@import '../../mixins';\r\n\r\n.contain-text {\r\n    display: inline-block;\r\n    max-width: 35rem;\r\n    overflow: hidden;\r\n    text-overflow: ellipsis;\r\n    white-space: nowrap;\r\n}\r\n\r\na {\r\n    font-weight: normal !important;\r\n}\r\n\r\n@include media-breakpoint-down(\"lg\"){\r\n    .contain-text {\r\n        max-width: 20rem;\r\n    }\r\n}\r\n\r\n@include media-breakpoint-down(\"sm\"){\r\n    .contain-text {\r\n        max-width: 15rem;\r\n    }\r\n}\r\n\r\n@include media-breakpoint-down(\"xs\"){\r\n    .contain-text {\r\n        max-width: 10rem;\r\n    }\r\n}",".contain-text {\n  display: inline-block;\n  max-width: 35rem;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n\na {\n  font-weight: normal !important;\n}\n\n@media (max-width: 1199.98px) {\n  .contain-text {\n    max-width: 20rem;\n  }\n}\n@media (max-width: 767.98px) {\n  .contain-text {\n    max-width: 15rem;\n  }\n}\n@media (max-width: 575.98px) {\n  .contain-text {\n    max-width: 10rem;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnInit, Input } from '@angular/core';\r\nimport { SafeUrl, DomSanitizer } from '@angular/platform-browser';\r\nimport { urlRegex } from 'src/infrastructure/utils';\r\n\r\n@Component({\r\n selector: 'link-or-text',\r\n templateUrl: './link-or-text.component.html',\r\n styleUrls: ['./link-or-text.component.scss']\r\n})\r\nexport class LinkOrTextComponent implements OnInit {\r\n\r\n constructor(\r\n private sanitizer: DomSanitizer\r\n ) { }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n textValue: string;\r\n safeUrl: SafeUrl;\r\n\r\n @Input('uri')\r\n set uri(value: string) {\r\n if (value && value.trim() && value.trim().match(urlRegex)) {\r\n this.textValue = value;\r\n this.safeUrl = this.sanitizer.bypassSecurityTrustUrl(value.trim());\r\n } else {\r\n this.textValue = value;\r\n this.safeUrl = null;\r\n }\r\n }\r\n}\r\n","module.exports = \":host {\\n position: fixed;\\n top: 0;\\n left: 0;\\n right: 0;\\n bottom: 0;\\n opacity: 0.8;\\n background-color: #ffffff;\\n z-index: 1;\\n}\\n\\n.lightbulb {\\n color: darkslategray;\\n position: fixed;\\n top: 50%;\\n left: 50%;\\n -webkit-transform: rotateZ(-15deg);\\n transform: rotateZ(-15deg);\\n -webkit-transform: translate(-50%, -50%);\\n transform: translate(-50%, -50%);\\n z-index: 2;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL2xvYWRpbmctaW5kaWNhdG9yL0M6XFxQcm9qZWN0c1xcb3BlbnNjaWVuY2VcXFBvcnRhbC5XZWJBcHBsaWNhdGlvbi9zcmNcXGNvbXBvbmVudHNcXGxvYWRpbmctaW5kaWNhdG9yXFxsb2FkaW5nLWluZGljYXRvci5jb21wb25lbnQuc2NzcyIsInNyYy9jb21wb25lbnRzL2xvYWRpbmctaW5kaWNhdG9yL0M6XFxQcm9qZWN0c1xcb3BlbnNjaWVuY2VcXFBvcnRhbC5XZWJBcHBsaWNhdGlvbi9zcmNcXHZhcmlhYmxlcy5zY3NzIiwic3JjL2NvbXBvbmVudHMvbG9hZGluZy1pbmRpY2F0b3IvbG9hZGluZy1pbmRpY2F0b3IuY29tcG9uZW50LnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7RUFDRSxlQUFBO0VBQ0EsTUFBQTtFQUNBLE9BQUE7RUFDQSxRQUFBO0VBQ0EsU0FBQTtFQUNBLFlBQUE7RUFDQSx5QkNGTTtFREdOLFVBQUE7QUVERjs7QUZJQTtFQUNFLG9CQUFBO0VBQ0EsZUFBQTtFQUNBLFFBQUE7RUFDQSxTQUFBO0VBQ0Esa0NBQUE7VUFBQSwwQkFBQTtFQUNBLHdDQUFBO1VBQUEsZ0NBQUE7RUFDQSxVQUFBO0FFREYiLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvbG9hZGluZy1pbmRpY2F0b3IvbG9hZGluZy1pbmRpY2F0b3IuY29tcG9uZW50LnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyJAaW1wb3J0ICcuLi8uLi92YXJpYWJsZXMnO1xyXG5cclxuOmhvc3Qge1xyXG4gIHBvc2l0aW9uOiBmaXhlZDtcclxuICB0b3A6IDA7XHJcbiAgbGVmdDogMDtcclxuICByaWdodDogMDtcclxuICBib3R0b206IDA7XHJcbiAgb3BhY2l0eTogLjg7XHJcbiAgYmFja2dyb3VuZC1jb2xvcjogJHdoaXRlO1xyXG4gIHotaW5kZXg6IDE7XHJcbn1cclxuXHJcbi5saWdodGJ1bGIge1xyXG4gIGNvbG9yOiBkYXJrc2xhdGVncmF5O1xyXG4gIHBvc2l0aW9uOiBmaXhlZDtcclxuICB0b3A6IDUwJTtcclxuICBsZWZ0OiA1MCU7XHJcbiAgdHJhbnNmb3JtOnJvdGF0ZVooLTE1ZGVnKTtcclxuICB0cmFuc2Zvcm06IHRyYW5zbGF0ZSgtNTAlLCAtNTAlKTtcclxuICB6LWluZGV4OiAyO1xyXG59IiwiLy8gJGJsdWU6ICMxOTBlOGY7XHJcbiRibHVlOiAjMDA3MmI1O1xyXG4vLyAkYmx1ZTogI0E4QjEwRTtcclxuLy8gJHBhc3RlbC1ibHVlOiAjQThCMTBFO1xyXG4kcGFzdGVsLWJsdWU6ICMwMDcyYjU7XHJcbiRvcmFuZ2U6ICNmZjk4MDA7XHJcbiRwYXN0ZWwtb3JhbmdlOiAjRkZCODREO1xyXG4kd2hpdGU6ICNmZmZmZmY7XHJcbiRncmF5OiAjYjRiNGI0O1xyXG4kbm9ybWFsOiAjNjk2OTY5O1xyXG4kYmxhY2s6IGRhcmtlbigkbm9ybWFsLCA3NSUpO1xyXG5cclxuJHByaW1hcnk6ICRibHVlO1xyXG4kc2Vjb25kYXJ5OiAkb3JhbmdlO1xyXG5cclxuJHRoZW1lLWNvbG9ycyA6IChcclxuICBcInNlY29uZGFyeVwiOiAgJHNlY29uZGFyeSxcclxuICBcIm5vcm1hbFwiOiAkbm9ybWFsLFxyXG4gIFwicGFzdGVsLWJsdWVcIjogJHBhc3RlbC1ibHVlLFxyXG4gIFwicGFzdGVsLW9yYW5nZVwiOiAkcGFzdGVsLW9yYW5nZVxyXG4pO1xyXG5cclxuJGdyaWQtYnJlYWtwb2ludHM6IChcclxuICB4czogMCxcclxuICBzbTogNTc2cHgsXHJcbiAgbWQ6IDc2OHB4LFxyXG4gIGxnOiA5OTJweCxcclxuICB4bDogMTIwMHB4XHJcbik7XHJcblxyXG4kY29udGFpbmVyLW1heC13aWR0aHM6IChcclxuICBzbTogNzY4cHgsXHJcbiAgbWQ6IDk1OXB4LFxyXG4gIGxnOiA5NjBweCxcclxuICB4bDogMTIwMHB4XHJcbik7XHJcblxyXG4kaW5wdXQtYm9yZGVyLXNpemU6IDFweDtcclxuJGJvcmRlci1zaXplOiAycHg7IiwiOmhvc3Qge1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgcmlnaHQ6IDA7XG4gIGJvdHRvbTogMDtcbiAgb3BhY2l0eTogMC44O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZmZmZmZmO1xuICB6LWluZGV4OiAxO1xufVxuXG4ubGlnaHRidWxiIHtcbiAgY29sb3I6IGRhcmtzbGF0ZWdyYXk7XG4gIHBvc2l0aW9uOiBmaXhlZDtcbiAgdG9wOiA1MCU7XG4gIGxlZnQ6IDUwJTtcbiAgdHJhbnNmb3JtOiByb3RhdGVaKC0xNWRlZyk7XG4gIHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIC01MCUpO1xuICB6LWluZGV4OiAyO1xufSJdfQ== */\"","import { Component } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'ab-loading-indicator',\r\n templateUrl: './loading-indicator.component.html',\r\n styleUrls: ['./loading-indicator.component.scss']\r\n})\r\nexport class LoadingIndicatorComponent { }\r\n","import { Component, Input } from \"@angular/core\";\r\nimport { faSpinner } from '@fortawesome/free-solid-svg-icons';\r\n\r\n@Component({\r\n selector: 'loading-section',\r\n templateUrl: 'loading-section.component.html'\r\n})\r\nexport class LoadingSectionComponent {\r\n\r\n loadingIcon = faSpinner;\r\n\r\n @Input() loadingText = 'loadingSection.text';\r\n @Input() iconSize = 'fa-3x';\r\n @Input() marginSize = '4';\r\n}","module.exports = \".pages-container {\\n font-size: 16px;\\n color: black;\\n margin-left: -8px;\\n}\\n.pages-container > * {\\n margin-left: 8px;\\n margin-top: 8px;\\n}\\n.ab-page {\\n margin: 4px 2px;\\n padding: 2px 8px;\\n color: #0072b5;\\n cursor: pointer;\\n -webkit-transition: color 0.15s linear;\\n transition: color 0.15s linear;\\n}\\n.ab-page.active {\\n background-color: #0072b5;\\n color: #ffffff;\\n text-decoration: none;\\n}\\n.ab-page:not(.active):hover {\\n color: #ff9800;\\n}\\n.ab-page-link {\\n margin: 0px 8px;\\n color: #0072b5;\\n -webkit-transition: color 0.15s linear;\\n transition: color 0.15s linear;\\n cursor: pointer;\\n}\\n.ab-page-link:hover {\\n color: #ff9800;\\n}\\n@media (max-width: 767.98px) {\\n .pages-container {\\n font-size: 14px;\\n }\\n\\n #pages-label {\\n display: none !important;\\n }\\n}\\n@media (max-width: 575.98px) {\\n .dots {\\n display: none;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/components/paginator/C:\\Projects\\openscience\\Portal.WebApplication/src\\components\\paginator\\paginator.component.scss","src/components/paginator/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/components/paginator/paginator.component.scss","src/components/paginator/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAGA;EACE,eAAA;EACA,YCKM;EDJN,iBAAA;AEFF;AFIE;EACE,gBAAA;EACA,eAAA;AEFJ;AFMA;EACE,eAAA;EACA,gBAAA;EACA,cChBK;EDiBL,eAAA;EACA,sCAAA;EAAA,8BAAA;AEHF;AFKE;EACE,yBCrBG;EDsBH,cChBI;EDiBJ,qBAAA;AEHJ;AFME;EACE,cCvBK;ACmBT;AFQA;EACE,eAAA;EACA,cCjCK;EDkCL,sCAAA;EAAA,8BAAA;EACA,eAAA;AELF;AFOE;EACE,cClCK;AC6BT;ACuCI;EH7BF;IACE,eAAA;EENF;;EFSA;IACE,wBAAA;EENF;AACF;AC6BI;EHnBF;IACE,aAAA;EEPF;AACF","file":"src/components/paginator/paginator.component.scss","sourcesContent":["@import '../../variables';\r\n@import '../../mixins';\r\n\r\n.pages-container {\r\n  font-size: 16px;\r\n  color: $black;\r\n  margin-left: -8px;\r\n\r\n  & > * {\r\n    margin-left: 8px;\r\n    margin-top: 8px;\r\n  }\r\n}\r\n\r\n.ab-page {\r\n  margin:  4px 2px;\r\n  padding: 2px 8px;\r\n  color: $primary;\r\n  cursor: pointer;\r\n  transition: color .15s linear;\r\n\r\n  &.active {\r\n    background-color: $primary;\r\n    color: $white;\r\n    text-decoration: none;\r\n  }\r\n\r\n  &:not(.active):hover {\r\n    color: $secondary;\r\n  }\r\n}\r\n\r\n.ab-page-link {\r\n  margin: 0px 8px;\r\n  color: $primary;\r\n  transition: color .15s linear;\r\n  cursor: pointer;\r\n\r\n  &:hover {\r\n    color: $secondary;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"sm\"){\r\n  .pages-container {\r\n    font-size: 14px;\r\n  }\r\n\r\n  #pages-label {\r\n    display: none !important;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"xs\"){\r\n  .dots {\r\n    display: none;\r\n  }\r\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;",".pages-container {\n  font-size: 16px;\n  color: black;\n  margin-left: -8px;\n}\n.pages-container > * {\n  margin-left: 8px;\n  margin-top: 8px;\n}\n\n.ab-page {\n  margin: 4px 2px;\n  padding: 2px 8px;\n  color: #0072b5;\n  cursor: pointer;\n  transition: color 0.15s linear;\n}\n.ab-page.active {\n  background-color: #0072b5;\n  color: #ffffff;\n  text-decoration: none;\n}\n.ab-page:not(.active):hover {\n  color: #ff9800;\n}\n\n.ab-page-link {\n  margin: 0px 8px;\n  color: #0072b5;\n  transition: color 0.15s linear;\n  cursor: pointer;\n}\n.ab-page-link:hover {\n  color: #ff9800;\n}\n\n@media (max-width: 767.98px) {\n  .pages-container {\n    font-size: 14px;\n  }\n\n  #pages-label {\n    display: none !important;\n  }\n}\n@media (max-width: 575.98px) {\n  .dots {\n    display: none;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, Input, Output, EventEmitter, SimpleChanges, OnInit, OnChanges } from \"@angular/core\";\r\nimport { scrollToTop } from \"src/infrastructure/utils\";\r\n\r\nexport class PaginatorChangeEvent {\r\n page: number;\r\n pageSize: number;\r\n}\r\n\r\n@Component({\r\n selector: 'ab-paginator',\r\n templateUrl: 'paginator.component.html',\r\n styleUrls: ['paginator.component.scss']\r\n})\r\nexport class PaginatorComponent implements OnInit, OnChanges {\r\n @Input()\r\n page: number;\r\n\r\n @Input()\r\n pageSize: number;\r\n\r\n @Input()\r\n totalCount: number;\r\n\r\n @Input()\r\n styles: string\r\n\r\n @Output()\r\n change: EventEmitter = new EventEmitter();\r\n\r\n numberOfPages: number = 0;\r\n offset: number = 0;\r\n pagesShowing: number = 5;\r\n pages: number[];\r\n\r\n ngOnInit() {\r\n this.calculate();\r\n }\r\n\r\n ngOnChanges(changes: SimpleChanges) {\r\n if (changes['totalCount'] || changes['page'])\r\n this.calculate();\r\n }\r\n\r\n calculate() {\r\n this.numberOfPages = Math.ceil(this.totalCount / this.pageSize);\r\n this.pagesShowing = Math.min(this.numberOfPages, 5);\r\n let offset = Math.floor(this.pagesShowing / 2);\r\n\r\n if (this.page < offset)\r\n this.pages = range(0, this.pagesShowing);\r\n else if (this.page >= this.numberOfPages - offset)\r\n this.pages = range(this.numberOfPages - this.pagesShowing, this.numberOfPages);\r\n else\r\n this.pages = range(this.page - offset, this.page + offset + 1);\r\n }\r\n\r\n changePage(page: number) {\r\n this.page = page;\r\n this.calculate();\r\n this.change.emit({\r\n page: this.page,\r\n pageSize: this.pageSize\r\n });\r\n\r\n scrollToTop();\r\n }\r\n\r\n changePageSize(pageSize: number) {\r\n this.pageSize = pageSize;\r\n this.calculate();\r\n this.change.emit({\r\n page: this.page,\r\n pageSize: this.pageSize\r\n });\r\n }\r\n}\r\n\r\nfunction range(start: number, end: number, step = 1) {\r\n let result = [];\r\n for (let i = start; i < end; i += step)\r\n result.push(i);\r\n return result;\r\n}","module.exports = \".select-dropdown-toggle {\\n width: 100%;\\n border: none;\\n border-radius: 8px;\\n background: #ffffff;\\n padding: 11px 13px;\\n cursor: pointer;\\n}\\n.select-dropdown-toggle .select-dropdown-indicator {\\n padding-left: 11px;\\n}\\n.select-dropdown-toggle .select-dropdown-indicator fa-icon {\\n display: inline-block;\\n -webkit-transform: rotate(0deg);\\n transform: rotate(0deg);\\n -webkit-transition: -webkit-transform 0.2s ease-in-out;\\n transition: -webkit-transform 0.2s ease-in-out;\\n transition: transform 0.2s ease-in-out;\\n transition: transform 0.2s ease-in-out, -webkit-transform 0.2s ease-in-out;\\n font-size: 1.1;\\n color: black;\\n}\\n.select-dropdown-toggle .select-dropdown-indicator fa-icon.rotate-180 {\\n -webkit-transform: rotate(180deg);\\n transform: rotate(180deg);\\n}\\n.select-dropdown-menu {\\n width: 100%;\\n max-height: 300px;\\n overflow-y: scroll;\\n}\\n.select-dropdown-menu::-webkit-scrollbar {\\n width: 0.5em;\\n height: 0.5em;\\n}\\n.select-dropdown-menu::-webkit-scrollbar-thumb {\\n background: darkgray;\\n}\\n.select-dropdown-menu::-webkit-scrollbar-track {\\n background: #ffffff;\\n}\\n.select-dropdown-menu body {\\n scrollbar-face-color: darkgray;\\n scrollbar-track-color: #ffffff;\\n}\\n.select-dropdown-menu [ngbDropdownItem] {\\n background-color: #ffffff;\\n color: #696969;\\n -webkit-transition: all 0.1s ease-in;\\n transition: all 0.1s ease-in;\\n}\\n.select-dropdown-menu [ngbDropdownItem].selected {\\n background-color: #0072b5;\\n color: #ffffff;\\n}\\n.select-dropdown-menu [ngbDropdownItem]:hover {\\n background-color: #0072b5;\\n color: #ffffff;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/components/select/C:\\Projects\\openscience\\Portal.WebApplication/src\\components\\select\\select.component.scss","src/components/select/select.component.scss","src/components/select/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/components/select/C:\\Projects\\openscience\\Portal.WebApplication/src\\mixins.scss"],"names":[],"mappings":"AAGA;EACE,WAAA;EACA,YAAA;EACA,kBAAA;EACA,mBAAA;EACA,kBAAA;EACA,eAAA;ACFF;ADIE;EAEE,kBAAA;ACHJ;ADKI;EACE,qBAAA;EACA,+BAAA;UAAA,uBAAA;EACA,sDAAA;EAAA,8CAAA;EAAA,sCAAA;EAAA,0EAAA;EACA,cAAA;EACA,YEVE;ADOR;ADKM;EACE,iCAAA;UAAA,yBAAA;ACHR;ADSA;EACE,WAAA;EACA,iBAAA;EACA,kBAAA;ACNF;AETE;EACI,YHegB;EGdhB,aHcgB;ACHtB;AERE;EACI,oBHUsB;ACA5B;AEPE;EACI,mBDpBE;AD6BR;AELE;EACE,8BHCwB;EGAxB,8BD1BI;ADiCR;ADLE;EACE,yBE7BI;EF8BJ,cE5BK;EF6BL,oCAAA;EAAA,4BAAA;ACOJ;ADLI;EACE,yBErCQ;EFsCR,cEnCE;AD0CR;ADJI;EACE,yBE1CQ;EF2CR,cExCE;AD8CR","file":"src/components/select/select.component.scss","sourcesContent":["@import '../../variables';\r\n@import '../../mixins';\r\n\r\n.select-dropdown-toggle {\r\n  width: 100%;\r\n  border: none;\r\n  border-radius: 8px;\r\n  background: $white;\r\n  padding: 11px 13px;\r\n  cursor: pointer;\r\n\r\n  .select-dropdown-indicator {\r\n    // border-left: 1px solid $gray;\r\n    padding-left: 11px;\r\n\r\n    fa-icon {\r\n      display: inline-block;\r\n      transform: rotate(0deg);\r\n      transition: transform .2s ease-in-out;\r\n      font-size: 1.1;\r\n      color: $black;\r\n\r\n      &.rotate-180 {\r\n        transform: rotate(180deg);\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n.select-dropdown-menu {\r\n  width: 100%;\r\n  max-height: 300px;\r\n  overflow-y: scroll;\r\n  @include scrollbars(.5em, lighten($normal, 25%), $white);\r\n  \r\n  & [ngbDropdownItem] {\r\n    background-color: $white;\r\n    color: $normal;\r\n    transition: all .1s ease-in;\r\n\r\n    &.selected {\r\n      background-color: $pastel-blue;\r\n      color: $white;\r\n    }\r\n\r\n    &:hover {\r\n      background-color: $pastel-blue;\r\n      color: $white;\r\n    } \r\n  }\r\n}",".select-dropdown-toggle {\n  width: 100%;\n  border: none;\n  border-radius: 8px;\n  background: #ffffff;\n  padding: 11px 13px;\n  cursor: pointer;\n}\n.select-dropdown-toggle .select-dropdown-indicator {\n  padding-left: 11px;\n}\n.select-dropdown-toggle .select-dropdown-indicator fa-icon {\n  display: inline-block;\n  transform: rotate(0deg);\n  transition: transform 0.2s ease-in-out;\n  font-size: 1.1;\n  color: black;\n}\n.select-dropdown-toggle .select-dropdown-indicator fa-icon.rotate-180 {\n  transform: rotate(180deg);\n}\n\n.select-dropdown-menu {\n  width: 100%;\n  max-height: 300px;\n  overflow-y: scroll;\n}\n.select-dropdown-menu::-webkit-scrollbar {\n  width: 0.5em;\n  height: 0.5em;\n}\n.select-dropdown-menu::-webkit-scrollbar-thumb {\n  background: darkgray;\n}\n.select-dropdown-menu::-webkit-scrollbar-track {\n  background: #ffffff;\n}\n.select-dropdown-menu body {\n  scrollbar-face-color: darkgray;\n  scrollbar-track-color: #ffffff;\n}\n.select-dropdown-menu [ngbDropdownItem] {\n  background-color: #ffffff;\n  color: #696969;\n  transition: all 0.1s ease-in;\n}\n.select-dropdown-menu [ngbDropdownItem].selected {\n  background-color: #0072b5;\n  color: #ffffff;\n}\n.select-dropdown-menu [ngbDropdownItem]:hover {\n  background-color: #0072b5;\n  color: #ffffff;\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","@import \"node_modules/bootstrap/scss/mixins/_breakpoints.scss\";\r\n@import \"variables\";\r\n\r\n/// Mixin to customize scrollbars\r\n/// Beware, this does not work in all browsers\r\n/// @author Hugo Giraudel\r\n/// @param {Length} $size - Horizontal scrollbar's height and vertical scrollbar's width\r\n/// @param {Color} $foreground-color - Scrollbar's color\r\n/// @param {Color} $background-color [mix($foreground-color, white, 50%)] - Scrollbar's color\r\n/// @example scss - Scrollbar styling\r\n///   @include scrollbars(.5em, slategray);\r\n@mixin scrollbars(\r\n  $size, \r\n  $foreground-color, \r\n  $background-color: mix($foreground-color, white,  50%)\r\n) {\r\n  // For Google Chrome\r\n  &::-webkit-scrollbar {\r\n      width:  $size;\r\n      height: $size;\r\n  }\r\n\r\n  &::-webkit-scrollbar-thumb {\r\n      background: $foreground-color;\r\n  }\r\n\r\n  &::-webkit-scrollbar-track {\r\n      background: $background-color;\r\n  }\r\n\r\n  // For Internet Explorer\r\n  & body {\r\n    scrollbar-face-color: $foreground-color;\r\n    scrollbar-track-color: $background-color;\r\n  }\r\n}\r\n\r\n@mixin formToggles(\r\n  $fontSize:16px, \r\n  $lineHeight: 1.5rem, \r\n  $border:2, \r\n  $bg: $primary, \r\n  $fg: #FFFFFF, \r\n  $disable: #CCCCCC\r\n) {\r\n  // strip the units (expecting a px value, but remove so we've just got an int)\r\n  $baseFont: ($fontSize) / ($fontSize * 0 + 1);\r\n  // ensure our base is a rem val\r\n  $base: ($lineHeight) / ($lineHeight * 0 + 1) * 1rem;\r\n  // get our borderwidth in rems\r\n  $borderWidth: (($border) / ($border * 0 + 1) / $baseFont) * 1rem;\r\n  .toggles {\r\n    label {\r\n      line-height: $base;\r\n      position: relative;\r\n      display: inline-block;\r\n      padding-left: $base;\r\n      width: 100%;\r\n      margin-bottom: 0;\r\n      &:before,\r\n      &:after {\r\n        box-sizing: border-box;\r\n        line-height: $base;\r\n        content: ' ';\r\n        display: block;\r\n        position: absolute;\r\n        top: $base/4.1;\r\n        left: 0;\r\n        width: $base/2;\r\n        height: $base/2;\r\n        border-radius: 100%;\r\n      }\r\n      &:before {\r\n        width: ($base/2)+$borderWidth*2;\r\n        height: ($base/2)+$borderWidth*2;\r\n        margin: -$borderWidth;\r\n        transition: background .36s;\r\n      }\r\n      /* Radio's setup */\r\n      &:after {\r\n        border: $borderWidth solid $fg;\r\n        transform: scale(0);\r\n        transition: background .12s, transform .16s;\r\n      }\r\n      /* The radio button background */\r\n      &:before {\r\n        border: $borderWidth solid $bg;\r\n      }\r\n      /* Checkbox setup */\r\n      &.checkbox:before,\r\n      &.checkbox:after {\r\n        border-radius: 0;\r\n      }\r\n      /* the check box background */\r\n      &.checkbox:before {\r\n        width: ($base/2)+$borderWidth*2;\r\n        height: ($base/2)+$borderWidth*2;\r\n        border-radius: 0;\r\n      }\r\n      /* Label hover state */\r\n      &:hover {\r\n        color: $bg;\r\n      }\r\n      /* Create an alternative stlye for switches */\r\n      &.switch {\r\n        padding-left: $base * 1.5;\r\n        display: block;\r\n        &:before {\r\n          width: ($base)+$borderWidth*2;\r\n          height: ($base/2)+$borderWidth*2;\r\n          border: $borderWidth solid $disable;\r\n        }\r\n        &:After {\r\n          transform: scale(1);\r\n          background: $disable;\r\n        }\r\n        &.round:before {\r\n          border-radius: 40%/80%;\r\n        }\r\n        &.round:after {\r\n          border-radius: 100%;\r\n        }\r\n        &.material:before {\r\n          top: $base/4+$borderWidth*2;\r\n          width: ($base)+$borderWidth*2;\r\n          height: ($base/2)-$borderWidth*2;\r\n          border-radius: 20%/40%;\r\n          border: none;\r\n          background: lighten($disable, 14%);\r\n        }\r\n        &.material:after {\r\n          top: $base/4-$borderWidth;\r\n          left: -$borderWidth;\r\n          border: none;\r\n          border-radius: 100%;\r\n          width: $base/2+$borderWidth*2;\r\n          height: $base/2+$borderWidth*2;\r\n        }\r\n      }\r\n    }\r\n    /* Hide the input elements and use there psuedo elements */\r\n    input[type=\"radio\"] {\r\n      display: none;\r\n      &:checked + label:after {\r\n        transform: scale(1);\r\n        background: $bg;\r\n      }\r\n    }\r\n    /* hide the input element */\r\n    input[type=\"checkbox\"] {\r\n      display: none;\r\n      /* style active state psuedo element */\r\n      &:checked + label:after {\r\n        content: '\\2713';\r\n        display: inline-block;\r\n        background: #fff;\r\n        color:$bg;\r\n        line-height: $base/2+$borderWidth;\r\n        font-size: $base/2;\r\n        font-weight: bold;\r\n        text-align: center;\r\n        transform: scale(1);\r\n        border: none;\r\n      }\r\n    }\r\n    // switch active states\r\n    input[type=\"radio\"],\r\n    input[type=\"checkbox\"] {\r\n      /* Add additional adjustments for switch style */\r\n      &:checked + label.switch {\r\n        &:before {\r\n          border-color: $bg;\r\n        }\r\n        &.material:before {\r\n          background: lighten($primary, 4%);\r\n        }\r\n      }\r\n      &:checked + label.switch {\r\n        &:after {\r\n          // no 3d, to support ie9+\r\n          transform: translateX($base*0.5);\r\n          border: $borderWidth solid $fg;\r\n          content: '';\r\n        }\r\n        &.material:after {\r\n          background: $primary;\r\n          border: none;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}"]} */\"","import { Component, Input, ViewChild, OnInit, ContentChild, TemplateRef, ElementRef } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { faAngleDown } from '@fortawesome/free-solid-svg-icons';\r\nimport { NgbDropdown } from '@ng-bootstrap/ng-bootstrap';\r\nimport { parseScrollEvent, ScrollType } from 'src/infrastructure/utils';\r\n\r\n/**\r\n * @usage\r\n * \">\r\n \r\n {{item}}\r\n \r\n \r\n {{value}}\r\n \r\n \r\n */\r\n@Component({\r\n selector: 'ab-select',\r\n templateUrl: 'select.component.html',\r\n styleUrls: ['select.component.scss'],\r\n providers: [\r\n {\r\n provide: NG_VALUE_ACCESSOR,\r\n useExisting: SelectComponent,\r\n multi: true\r\n }\r\n ]\r\n})\r\nexport class SelectComponent implements ControlValueAccessor, OnInit {\r\n @Input()\r\n collection: any[] = [];\r\n\r\n @ContentChild('dropdownItemTemplate', { static: true })\r\n dropdownItemTemplate: TemplateRef;\r\n\r\n @ContentChild('selectedItemTemplate', { static: true })\r\n selectedItemTemplate: TemplateRef;\r\n\r\n @ViewChild('dropdown', { static: true })\r\n dropdown: NgbDropdown;\r\n\r\n @ViewChild('dropdownMenu', { static: true })\r\n dropdownMenu: ElementRef;\r\n\r\n value: any;\r\n isOpen: boolean;\r\n formControlChangeHandler: any;\r\n faAngleDown = faAngleDown;\r\n\r\n ngOnInit() {\r\n this.dropdown.openChange.subscribe((isOpen: boolean) => this.isOpen = isOpen);\r\n }\r\n\r\n writeValue(obj: any): void {\r\n this.value = obj;\r\n }\r\n\r\n registerOnChange(fn: any): void {\r\n this.formControlChangeHandler = fn;\r\n }\r\n\r\n registerOnTouched(fn: any): void {\r\n }\r\n\r\n selectItem(item: any) {\r\n this.value = item;\r\n this.formControlChangeHandler(this.value);\r\n }\r\n\r\n limitScroll(event: WheelEvent) {\r\n var eventType = parseScrollEvent(event, this.dropdownMenu.nativeElement);\r\n if (eventType != ScrollType.middle)\r\n event.preventDefault();\r\n }\r\n}","module.exports = \".show-more-label-container {\\n margin-top: 8px;\\n}\\n\\n:host[footer] .link.primary {\\n color: #ffffff;\\n font-weight: normal;\\n}\\n\\n:host[footer] .link.primary:hover {\\n color: #ff9800;\\n}\\n\\n:host[footer] .show-more-label-container {\\n margin-top: 0px;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL3Nob3ctbW9yZS9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFxjb21wb25lbnRzXFxzaG93LW1vcmVcXHNob3ctbW9yZS5jb21wb25lbnQuc2NzcyIsInNyYy9jb21wb25lbnRzL3Nob3ctbW9yZS9zaG93LW1vcmUuY29tcG9uZW50LnNjc3MiLCJzcmMvY29tcG9uZW50cy9zaG93LW1vcmUvQzpcXFByb2plY3RzXFxvcGVuc2NpZW5jZVxcUG9ydGFsLldlYkFwcGxpY2F0aW9uL3NyY1xcdmFyaWFibGVzLnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7RUFDRSxlQUFBO0FDREY7O0FES0U7RUFDRSxjRURJO0VGRUosbUJBQUE7QUNGSjs7QURJSTtFQUNFLGNFUEc7QURLVDs7QURNRTtFQUNFLGVBQUE7QUNKSiIsImZpbGUiOiJzcmMvY29tcG9uZW50cy9zaG93LW1vcmUvc2hvdy1tb3JlLmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiQGltcG9ydCAnLi4vLi4vdmFyaWFibGVzJztcclxuXHJcbi5zaG93LW1vcmUtbGFiZWwtY29udGFpbmVyIHtcclxuICBtYXJnaW4tdG9wOiA4cHg7XHJcbn1cclxuXHJcbjpob3N0W2Zvb3Rlcl17XHJcbiAgLmxpbmsucHJpbWFyeSB7XHJcbiAgICBjb2xvcjogJHdoaXRlO1xyXG4gICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcclxuXHJcbiAgICAmOmhvdmVyIHtcclxuICAgICAgY29sb3I6ICRzZWNvbmRhcnk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAuc2hvdy1tb3JlLWxhYmVsLWNvbnRhaW5lciB7XHJcbiAgICBtYXJnaW4tdG9wOiAwcHg7XHJcbiAgfVxyXG59IiwiLnNob3ctbW9yZS1sYWJlbC1jb250YWluZXIge1xuICBtYXJnaW4tdG9wOiA4cHg7XG59XG5cbjpob3N0W2Zvb3Rlcl0gLmxpbmsucHJpbWFyeSB7XG4gIGNvbG9yOiAjZmZmZmZmO1xuICBmb250LXdlaWdodDogbm9ybWFsO1xufVxuOmhvc3RbZm9vdGVyXSAubGluay5wcmltYXJ5OmhvdmVyIHtcbiAgY29sb3I6ICNmZjk4MDA7XG59XG46aG9zdFtmb290ZXJdIC5zaG93LW1vcmUtbGFiZWwtY29udGFpbmVyIHtcbiAgbWFyZ2luLXRvcDogMHB4O1xufSIsIi8vICRibHVlOiAjMTkwZThmO1xyXG4kYmx1ZTogIzAwNzJiNTtcclxuLy8gJGJsdWU6ICNBOEIxMEU7XHJcbi8vICRwYXN0ZWwtYmx1ZTogI0E4QjEwRTtcclxuJHBhc3RlbC1ibHVlOiAjMDA3MmI1O1xyXG4kb3JhbmdlOiAjZmY5ODAwO1xyXG4kcGFzdGVsLW9yYW5nZTogI0ZGQjg0RDtcclxuJHdoaXRlOiAjZmZmZmZmO1xyXG4kZ3JheTogI2I0YjRiNDtcclxuJG5vcm1hbDogIzY5Njk2OTtcclxuJGJsYWNrOiBkYXJrZW4oJG5vcm1hbCwgNzUlKTtcclxuXHJcbiRwcmltYXJ5OiAkYmx1ZTtcclxuJHNlY29uZGFyeTogJG9yYW5nZTtcclxuXHJcbiR0aGVtZS1jb2xvcnMgOiAoXHJcbiAgXCJzZWNvbmRhcnlcIjogICRzZWNvbmRhcnksXHJcbiAgXCJub3JtYWxcIjogJG5vcm1hbCxcclxuICBcInBhc3RlbC1ibHVlXCI6ICRwYXN0ZWwtYmx1ZSxcclxuICBcInBhc3RlbC1vcmFuZ2VcIjogJHBhc3RlbC1vcmFuZ2VcclxuKTtcclxuXHJcbiRncmlkLWJyZWFrcG9pbnRzOiAoXHJcbiAgeHM6IDAsXHJcbiAgc206IDU3NnB4LFxyXG4gIG1kOiA3NjhweCxcclxuICBsZzogOTkycHgsXHJcbiAgeGw6IDEyMDBweFxyXG4pO1xyXG5cclxuJGNvbnRhaW5lci1tYXgtd2lkdGhzOiAoXHJcbiAgc206IDc2OHB4LFxyXG4gIG1kOiA5NTlweCxcclxuICBsZzogOTYwcHgsXHJcbiAgeGw6IDEyMDBweFxyXG4pO1xyXG5cclxuJGlucHV0LWJvcmRlci1zaXplOiAxcHg7XHJcbiRib3JkZXItc2l6ZTogMnB4OyJdfQ== */\"","import { Component, OnInit, Input, TemplateRef, ElementRef, ContentChild } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'app-show-more',\r\n templateUrl: './show-more.component.html',\r\n styleUrls: ['./show-more.component.scss']\r\n})\r\nexport class ShowMoreComponent {\r\n @Input()\r\n collection: Array = [];\r\n\r\n @Input()\r\n visibleItems: number = 4;\r\n\r\n @Input()\r\n marginLeft: number = 0;\r\n\r\n @Input()\r\n once: boolean = false;\r\n\r\n showMore: boolean = false;\r\n\r\n currentScroll: number;\r\n\r\n @ContentChild('itemTemplate', { static: true })\r\n itemTemplate: TemplateRef;\r\n\r\n show() {\r\n this.currentScroll = document.documentElement.scrollTop || document.body.scrollTop;\r\n this.showMore = true;\r\n }\r\n\r\n hide() {\r\n this.showMore = false;\r\n window.scrollTo(0, this.currentScroll);\r\n }\r\n}\r\n","// This file can be replaced during build by using the `fileReplacements` array.\r\n// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`.\r\n// The list of file replacements can be found in `angular.json`.\r\n\r\nexport const environment = {\r\n production: false\r\n};\r\n\r\n/*\r\n * For easier debugging in development mode, you can import the following file\r\n * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.\r\n *\r\n * This import should be commented out in production mode because it will have a negative impact\r\n * on performance if an error is thrown.\r\n */\r\n// import 'zone.js/dist/zone-error'; // Included with Angular CLI.\r\n","import { HttpClient } from '@angular/common/http';\r\nimport { Configuration } from './configuration/configuration';\r\nimport { Optional } from '@angular/core';\r\n\r\nexport class BaseResource {\r\n protected baseUrl: string;\r\n\r\n constructor(\r\n protected http: HttpClient,\r\n protected configuration: Configuration,\r\n protected suffix?: string\r\n ) {\r\n this.baseUrl = `${this.configuration.restUrl}`;\r\n this.setSuffix(suffix);\r\n }\r\n\r\n public getBaseUrl(): string {\r\n return this.baseUrl;\r\n }\r\n\r\n public setSuffix(suffix?: string): void {\r\n if (suffix) {\r\n this.baseUrl = `${this.configuration.restUrl}/${suffix}`;\r\n }\r\n }\r\n\r\n public composeQueryString(object: any): string {\r\n let result = '';\r\n let isFirst = true;\r\n\r\n if (object) {\r\n Object.keys(object).forEach(key => {\r\n if (isFirst) {\r\n result = '?' + key + '=' + object[key];\r\n isFirst = false;\r\n } else {\r\n result += '&' + key + '=' + object[key];\r\n }\r\n });\r\n }\r\n\r\n return result;\r\n }\r\n}\r\n","import { HttpClient } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\n\r\n@Injectable()\r\nexport class Configuration {\r\n clientUrl: string;\r\n restUrl: string;\r\n internalAppUrl: string;\r\n\r\n enableAnalytics: boolean = false;\r\n analyticsTrackingId: string = null;\r\n\r\n constructor(\r\n private httpClient: HttpClient\r\n ) { }\r\n\r\n load(): Promise<{}> {\r\n return new Promise((resolve) => {\r\n this.httpClient.get('./../../../configuration.json')\r\n .subscribe((e) => {\r\n this.importSettings(e);\r\n resolve(true);\r\n });\r\n });\r\n }\r\n\r\n private importSettings(config: any) {\r\n if (config.restUrlFromAppOrigin) {\r\n config.urls.restUrl = `${window.location.origin}/api`;\r\n config.urls.clientUrl = `${window.location.origin}`;\r\n }\r\n\r\n this.restUrl = config.urls.restUrl;\r\n this.clientUrl = config.urls.clientUrl;\r\n this.internalAppUrl = config.urls.internalAppUrl;\r\n if (config.analytics && config.analytics.enableAnalytics && config.analytics.analyticsTrackingId) {\r\n this.enableAnalytics = config.analytics.enableAnalytics;\r\n this.analyticsTrackingId = config.analytics.analyticsTrackingId;\r\n }\r\n }\r\n}\r\n\r\nexport function configurationFactory(configuration: Configuration): Function {\r\n return () => configuration.load();\r\n}\r\n","import { Injectable, EventEmitter } from \"@angular/core\";\r\nimport { ReplaySubject } from 'rxjs';\r\nimport { debounce, debounceTime, distinctUntilChanged } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class LoadingIndicatorService {\r\n subject: ReplaySubject = new ReplaySubject();\r\n change$ = this.subject.pipe(debounceTime(300), distinctUntilChanged());\r\n\r\n start() {\r\n this.subject.next(true);\r\n }\r\n\r\n stop() {\r\n this.subject.next(false)\r\n }\r\n}","//Chosse Locale From This Link\r\n//https://github.com/angular/angular/tree/master/packages/common/locales\r\n\r\nimport { Injectable } from '@angular/core';\r\nimport { Debug, DebugVerbosity } from './debug.decorator';\r\n\r\n@Injectable()\r\nexport class LocaleService {\r\n constructor() { }\r\n\r\n private _defaultLocale = 'bg-BG';\r\n private _locale: string;\r\n set locale(value: string) {\r\n this._locale = value;\r\n }\r\n get locale(): string {\r\n return this._locale || 'en-GB';\r\n }\r\n\r\n private _defaultCulture = 'bg';\r\n private _culture: string;\r\n set culture(value: string) {\r\n this._culture = value;\r\n localStorage.setItem(\"culture\", value);\r\n }\r\n\r\n get culture() {\r\n return localStorage.getItem(\"culture\") || this._culture || this._defaultCulture;\r\n }\r\n\r\n // @Debug({\r\n // verbosity: DebugVerbosity.methodVerbose\r\n // })\r\n public changeCulture(culture: string) {\r\n switch (culture) {\r\n case 'en': {\r\n this._locale = 'en-GB';\r\n this.culture = culture;\r\n break;\r\n }\r\n case 'bg': {\r\n this._locale = 'bg-BG';\r\n this.culture = culture;\r\n break;\r\n }\r\n default: {\r\n this._locale = this._defaultLocale;\r\n this.culture = this._defaultCulture;\r\n break;\r\n }\r\n }\r\n }\r\n}","import { NgModule } from \"@angular/core\";\r\nimport { NgbDropdownModule, NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\r\n\r\n@NgModule({\r\n imports: [\r\n NgbDropdownModule,\r\n NgbTooltipModule\r\n ],\r\n exports: [\r\n NgbDropdownModule,\r\n NgbTooltipModule\r\n ]\r\n})\r\nexport class NgBootstrapModule { }","import { Router, ActivatedRoute, NavigationEnd, Params } from '@angular/router';\r\nimport { TranslateService, LangChangeEvent } from '@ngx-translate/core';\r\nimport { filter, map, mergeMap, switchMap, tap, last } from 'rxjs/operators';\r\nimport { of, from, merge } from 'rxjs';\r\nimport { SearchMode } from 'src/search/models/search-mode.enum';\r\nimport { SearchField } from 'src/search/models/search-field';\r\nimport { SEARCH_FIELD_SPEC } from 'src/search/models/search-field-type-spec';\r\nimport { SearchEvent } from 'src/search/models/search-event';\r\nimport { LocaleService } from './locale.service';\r\n\r\ndeclare let gtag: Function;\r\n\r\nexport enum ScrollType {\r\n top = 1,\r\n bottom = 2,\r\n middle = 3\r\n}\r\n\r\nexport function parseScrollEvent(event: WheelEvent, target: HTMLElement) {\r\n const atBottom = target.scrollHeight - Math.ceil(target.scrollTop) === target.clientHeight;\r\n const atTop = Math.ceil(target.scrollTop) === 0;\r\n\r\n if (event.deltaY > 0 && atBottom)\r\n return ScrollType.bottom;\r\n else if (event.deltaY < 0 && atTop)\r\n return ScrollType.top;\r\n else\r\n return ScrollType.middle;\r\n}\r\n\r\nexport function clone(obj: T): T {\r\n if (!obj)\r\n return obj;\r\n return JSON.parse(JSON.stringify(obj));\r\n}\r\n\r\nexport function initLocalization(\r\n activatedRoute: ActivatedRoute,\r\n translate: TranslateService,\r\n localeService: LocaleService\r\n) {\r\n translate.setDefaultLang('bg');\r\n\r\n translate.onLangChange\r\n .subscribe((event: LangChangeEvent) => {\r\n localeService.changeCulture(event.lang);\r\n });\r\n\r\n activatedRoute.queryParamMap.subscribe(params => {\r\n if (params.has('lang')\r\n && (params.get('lang') === 'bg' || params.get('lang') === 'en')) {\r\n translate.use(params.get('lang'));\r\n }\r\n });\r\n\r\n setTimeout(() => {\r\n if (!translate.currentLang)\r\n translate.use(localeService.culture);\r\n }, 0);\r\n}\r\n\r\nexport function getPageTitle(\r\n router: Router,\r\n activatedRoute: ActivatedRoute,\r\n translateService: TranslateService\r\n) {\r\n return router.events\r\n .pipe(\r\n filter((event) => event instanceof NavigationEnd),\r\n map(() => activatedRoute),\r\n map((route) => {\r\n while (route.firstChild) {\r\n route = route.firstChild;\r\n }\r\n return route;\r\n }),\r\n filter(route => route.outlet === 'primary'),\r\n mergeMap(route => route.data),\r\n switchMap(data => {\r\n if (data.data && data.data.name)\r\n return of(data.data.name);\r\n else if (data.publication && data.publication.titles && data.publication.titles[0] && typeof data.publication.titles[0] === 'string')\r\n return of(data.publication.titles[0]);\r\n else\r\n return translateService.stream(data['title'] || 'pages.default');\r\n })\r\n );\r\n}\r\n\r\nexport function getPageLanguage(\r\n router: Router\r\n) {\r\n return router.events\r\n .pipe(\r\n filter((event) => event instanceof NavigationEnd),\r\n map(_ => {\r\n let url = window.location.href;\r\n\r\n if (url.indexOf('/en/') !== -1)\r\n return 'en';\r\n else if (url.indexOf('/bg/') !== -1)\r\n return 'bg';\r\n else return null;\r\n }),\r\n filter(e => e != null)\r\n );\r\n}\r\n\r\nexport function getNavigationForGtag(router: Router) {\r\n return router.events\r\n .pipe(\r\n filter((event) => event instanceof NavigationEnd),\r\n map((e: NavigationEnd) => e.urlAfterRedirects)\r\n );\r\n}\r\n\r\nexport function gtagConfigEvent(url: string, trackingId: string) {\r\n gtag('config', trackingId, {\r\n 'page_path': url\r\n });\r\n}\r\n\r\nexport function scrollToTop(behavior: 'auto' | 'smooth' = 'smooth') {\r\n document.body.scrollTo({\r\n top: 0,\r\n left: 0,\r\n behavior\r\n });\r\n}\r\n\r\nexport const urlRegex = new RegExp(/^https?:\\/\\/(www\\.)?[-a-zA-Z0-9@:%._\\+~#=]{2,256}\\.[a-z]{2,4}\\b([-a-zA-Z0-9@:%_\\+.~#?&\\/=]*)$/);\r\n\r\nexport const copyText = (text: string) => {\r\n if (!navigator.clipboard) {\r\n // FALLBACK FOR OLDER BROWSERS\r\n\r\n let textArea = document.createElement(\"textarea\");\r\n textArea.value = text;\r\n\r\n // Avoid scrolling to bottom\r\n textArea.style.top = \"0\";\r\n textArea.style.left = \"0\";\r\n textArea.style.position = \"fixed\";\r\n\r\n document.body.appendChild(textArea);\r\n textArea.focus();\r\n textArea.select();\r\n\r\n let successful = false;\r\n\r\n try {\r\n successful = document.execCommand('copy');\r\n } catch (err) {\r\n successful = false;\r\n }\r\n\r\n document.body.removeChild(textArea);\r\n return of(successful)\r\n }\r\n else {\r\n return from(navigator.clipboard.writeText(text).then(_ => true, _ => false));\r\n }\r\n};\r\n\r\nexport const bindSearchParams = (self: any) => (model: SearchEvent) => {\r\n self.searchFields = (model.q || [])\r\n .filter((field: SearchField) => field.searchTerm !== SEARCH_FIELD_SPEC[field.type].defaultValue);\r\n self.searchMode = model.mode || SearchMode.simple;\r\n self.page = model.page || 0;\r\n}","import { enableProdMode } from '@angular/core';\r\nimport { platformBrowserDynamic } from '@angular/platform-browser-dynamic';\r\n\r\nimport { AppModule } from './app/app.module';\r\nimport { environment } from './environments/environment';\r\n\r\nimport bg from '@angular/common/locales/bg';\r\nimport en from '@angular/common/locales/en';\r\nimport { registerLocaleData } from '@angular/common';\r\n\r\nif (environment.production) {\r\n enableProdMode();\r\n}\r\n\r\nplatformBrowserDynamic().bootstrapModule(AppModule)\r\n .catch(err => console.error(err));\r\n\r\nwindow.history.scrollRestoration = 'manual';\r\nregisterLocaleData(bg);\r\nregisterLocaleData(en);","module.exports = \".breadcrumbs-header {\\n height: 85px;\\n background-color: #0072b5;\\n background-image: url('home_2.jpg');\\n background-size: cover;\\n background-repeat: no-repeat;\\n background-position: center;\\n}\\n.breadcrumbs-header .link-white {\\n font-weight: bold;\\n}\\n.breadcrumbs-header .container {\\n margin-top: initial;\\n}\\n.container {\\n margin-top: 60px;\\n}\\n.container.bold-links a {\\n font-weight: bold;\\n}\\n.container > * {\\n margin-left: 15px;\\n margin-right: 15px;\\n}\\n.title {\\n color: #0072b5;\\n font-size: 26px;\\n font-weight: bold;\\n margin-bottom: 48px;\\n}\\n.subtitle {\\n color: #ff9800;\\n font-size: 18px;\\n font-weight: bold;\\n text-transform: uppercase;\\n margin-bottom: 16px;\\n}\\n.sub-sub-title {\\n margin-top: 32px;\\n color: #0072b5;\\n font-weight: bold;\\n font-size: 16px;\\n}\\nh2 {\\n margin-top: 48px;\\n}\\n.content p + p {\\n margin-top: 16px;\\n}\\n.container:last-of-type(.content) {\\n border: 1px solid black;\\n}\\n.link-white {\\n font-weight: bold;\\n}\\n.link.primary {\\n font-weight: normal;\\n}\\n.link.bold {\\n font-weight: bold;\\n}\\n.link.long {\\n word-break: break-all;\\n}\\nul li {\\n text-align: justify;\\n}\\nul li + li {\\n margin-top: 8px;\\n}\\n@media (max-width: 575.98px) {\\n .container p,\\n.container li,\\n.container h1,\\n.container h2,\\n.container a {\\n text-align: left;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/C:\\Projects\\openscience\\Portal.WebApplication/src\\page-styles.scss","src/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/page-styles.scss","src/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAIA;EACE,YAAA;EACA,yBCLK;EDML,mCAAA;EACA,sBAAA;EACA,4BAAA;EACA,2BAAA;AEHF;AFKE;EACE,iBAAA;AEHJ;AFME;EACE,mBAAA;AEJJ;AFQA;EACE,gBAAA;AELF;AFOE;EACE,iBAAA;AELJ;AFQE;EACE,iBAAA;EACA,kBAAA;AENJ;AFUA;EACE,cClCK;EDmCL,eAAA;EACA,iBAAA;EACA,mBAAA;AEPF;AFUA;EACE,cCrCO;EDsCP,eAAA;EACA,iBAAA;EACA,yBAAA;EACA,mBAAA;AEPF;AFUA;EACE,gBAAA;EACA,cClDK;EDmDL,iBAAA;EACA,eAAA;AEPF;AFUA;EACE,gBAAA;AEPF;AFWE;EACE,gBAAA;AERJ;AFYA;EACE,uBAAA;AETF;AFYA;EACE,iBAAA;AETF;AFYA;EACE,mBAAA;AETF;AFYA;EACE,iBAAA;AETF;AFYA;EACE,qBAAA;AETF;AFaE;EACE,mBAAA;AEVJ;AFaE;EACE,eAAA;AEXJ;ACRI;EHyBA;;;;;IAKE,gBAAA;EEbJ;AACF","file":"src/page-styles.scss","sourcesContent":["@import './variables';\r\n@import './mixins';\r\n\r\n\r\n.breadcrumbs-header {\r\n  height: 85px;\r\n  background-color: $primary;\r\n  background-image: url('./assets/img/home_2.jpg');\r\n  background-size: cover;\r\n  background-repeat: no-repeat;\r\n  background-position: center;\r\n\r\n  .link-white {\r\n    font-weight: bold;\r\n  }\r\n\r\n  .container {\r\n    margin-top: initial;\r\n  }\r\n}\r\n\r\n.container  {\r\n  margin-top: 60px;\r\n\r\n  &.bold-links a {\r\n    font-weight: bold;\r\n  }\r\n\r\n  &>* {\r\n    margin-left: 15px;\r\n    margin-right: 15px;\r\n  }\r\n}\r\n\r\n.title {\r\n  color: $primary;\r\n  font-size: 26px;\r\n  font-weight: bold;\r\n  margin-bottom: 48px;\r\n}\r\n\r\n.subtitle {\r\n  color: $secondary;\r\n  font-size: 18px;\r\n  font-weight: bold;\r\n  text-transform: uppercase;\r\n  margin-bottom: 16px;\r\n}\r\n\r\n.sub-sub-title {\r\n  margin-top: 32px;\r\n  color: $primary;\r\n  font-weight: bold;\r\n  font-size: 16px;\r\n}\r\n\r\nh2 {\r\n  margin-top: 48px;\r\n}\r\n\r\n.content {\r\n  p + p{\r\n    margin-top: 16px;\r\n  }\r\n}\r\n\r\n.container:last-of-type(.content){\r\n  border: 1px solid black;\r\n}\r\n\r\n.link-white {\r\n  font-weight: bold;\r\n}\r\n\r\n.link.primary {\r\n  font-weight: normal;\r\n}\r\n\r\n.link.bold {\r\n  font-weight: bold;\r\n}\r\n\r\n.link.long {\r\n  word-break: break-all;\r\n}\r\n\r\nul {\r\n  li {\r\n    text-align: justify;\r\n  }\r\n\r\n  li + li {\r\n    margin-top: 8px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"xs\"){\r\n  .container {  \r\n    p,\r\n    li,\r\n    h1,\r\n    h2,\r\n    a {\r\n      text-align: left;\r\n    }\r\n  }\r\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;",".breadcrumbs-header {\n  height: 85px;\n  background-color: #0072b5;\n  background-image: url(\"./assets/img/home_2.jpg\");\n  background-size: cover;\n  background-repeat: no-repeat;\n  background-position: center;\n}\n.breadcrumbs-header .link-white {\n  font-weight: bold;\n}\n.breadcrumbs-header .container {\n  margin-top: initial;\n}\n\n.container {\n  margin-top: 60px;\n}\n.container.bold-links a {\n  font-weight: bold;\n}\n.container > * {\n  margin-left: 15px;\n  margin-right: 15px;\n}\n\n.title {\n  color: #0072b5;\n  font-size: 26px;\n  font-weight: bold;\n  margin-bottom: 48px;\n}\n\n.subtitle {\n  color: #ff9800;\n  font-size: 18px;\n  font-weight: bold;\n  text-transform: uppercase;\n  margin-bottom: 16px;\n}\n\n.sub-sub-title {\n  margin-top: 32px;\n  color: #0072b5;\n  font-weight: bold;\n  font-size: 16px;\n}\n\nh2 {\n  margin-top: 48px;\n}\n\n.content p + p {\n  margin-top: 16px;\n}\n\n.container:last-of-type(.content) {\n  border: 1px solid black;\n}\n\n.link-white {\n  font-weight: bold;\n}\n\n.link.primary {\n  font-weight: normal;\n}\n\n.link.bold {\n  font-weight: bold;\n}\n\n.link.long {\n  word-break: break-all;\n}\n\nul li {\n  text-align: justify;\n}\nul li + li {\n  margin-top: 8px;\n}\n\n@media (max-width: 575.98px) {\n  .container p,\n.container li,\n.container h1,\n.container h2,\n.container a {\n    text-align: left;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { Routes, RouterModule } from '@angular/router';\r\n\r\nconst routes: Routes = [\r\n {\r\n path: 'en',\r\n loadChildren: () => import('./english-pages.module').then(e => e.EnglishPagesModule)\r\n },\r\n {\r\n path: 'bg',\r\n loadChildren: () => import('./bulgarian-pages.module').then(e => e.BulgarianPagesModule)\r\n }\r\n];\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n TranslateModule,\r\n RouterModule.forChild(routes)\r\n ],\r\n exports: [\r\n RouterModule\r\n ]\r\n})\r\nexport class PagesModule { }\r\n","module.exports = \".highlighted {\\n margin-top: 8px;\\n padding: 8px;\\n background-color: whitesmoke;\\n}\\n.highlighted .label {\\n display: block;\\n font-weight: bold;\\n}\\n.highlighted .value {\\n margin-left: 32px;\\n margin-right: 32px;\\n text-align: justify;\\n}\\n.highlighted .value foreign-name-select:not(:last-child)::after {\\n content: \\\";\\\";\\n margin-left: -4px;\\n margin-right: 4px;\\n}\\n@media (max-width: 767.98px) {\\n .highlighted .value {\\n text-align: left;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/publication/components/publication-details/C:\\Projects\\openscience\\Portal.WebApplication/src\\publication\\components\\publication-details\\publication-details.component.scss","src/publication/components/publication-details/publication-details.component.scss","src/publication/components/publication-details/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAEA;EACE,eAAA;EACA,YAAA;EACA,4BAAA;ACDF;ADGE;EACE,cAAA;EACA,iBAAA;ACDJ;ADIE;EACE,iBAAA;EACA,kBAAA;EACA,mBAAA;ACFJ;ADII;EACE,YAAA;EACA,iBAAA;EACA,iBAAA;ACFN;ACuDI;EF9CA;IACE,gBAAA;ECLJ;AACF","file":"src/publication/components/publication-details/publication-details.component.scss","sourcesContent":["@import '../../../mixins.scss';\r\n\r\n.highlighted {\r\n  margin-top: 8px;\r\n  padding: 8px;\r\n  background-color: whitesmoke;\r\n\r\n  .label {\r\n    display: block;\r\n    font-weight: bold;\r\n  }\r\n\r\n  .value {\r\n    margin-left: 32px;\r\n    margin-right: 32px;\r\n    text-align: justify;\r\n\r\n    foreign-name-select:not(:last-child)::after {\r\n      content: \";\";\r\n      margin-left: -4px;\r\n      margin-right: 4px;  \r\n    }\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down('sm'){\r\n  .highlighted {\r\n    .value {\r\n      text-align: left;\r\n    }\r\n  }\r\n}",".highlighted {\n  margin-top: 8px;\n  padding: 8px;\n  background-color: whitesmoke;\n}\n.highlighted .label {\n  display: block;\n  font-weight: bold;\n}\n.highlighted .value {\n  margin-left: 32px;\n  margin-right: 32px;\n  text-align: justify;\n}\n.highlighted .value foreign-name-select:not(:last-child)::after {\n  content: \";\";\n  margin-left: -4px;\n  margin-right: 4px;\n}\n\n@media (max-width: 767.98px) {\n  .highlighted .value {\n    text-align: left;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnInit, Input } from '@angular/core';\r\nimport { Publication } from 'src/publication/models/publication';\r\nimport { faInfoCircle } from '@fortawesome/free-solid-svg-icons';\r\n\r\n@Component({\r\n selector: 'publication-details',\r\n templateUrl: './publication-details.component.html',\r\n styleUrls: ['./publication-details.component.scss']\r\n})\r\nexport class PublicationDetailsComponent implements OnInit {\r\n @Input()\r\n publication: Publication;\r\n detailsIcon = faInfoCircle;\r\n showDetails = false;\r\n\r\n contributors: string = null;\r\n fundingReference: string = null;\r\n relatedIdentifiers: string = null;\r\n alternativeIdentifiers: string = null;\r\n sources: string = null;\r\n coverages: string = null;\r\n\r\n constructor() { }\r\n\r\n ngOnInit() {\r\n // This is needed because text-align: justify breaks my soul\r\n this.contributors = this.publication.contributors.map(e => e.name.trim()).join(\"; \");\r\n this.fundingReference = this.publication.fundingReference.map(e => `${e.funderName.trim()}: ${e.awardTitle.trim()} (${e.awardNumber.trim()})`).join(\"; \");\r\n this.relatedIdentifiers = this.publication.relatedIdentifiers.map(e => e.trim()).join(\"; \");\r\n this.alternativeIdentifiers = this.publication.alternativeIdentifiers.map(e => e.trim()).join(\"; \");\r\n this.sources = this.publication.sources.map(e => e.trim()).join(\"; \");\r\n this.coverages = this.publication.coverages.map(e => e.trim()).join(\"; \");\r\n }\r\n}\r\n","module.exports = \".breadcrumbs-header {\\n height: 85px;\\n background-color: #0072b5;\\n background-image: url('home_2.jpg');\\n background-size: cover;\\n background-repeat: no-repeat;\\n background-position: center;\\n}\\n\\n#publication-container {\\n margin-left: -32px;\\n}\\n\\n#publication-container > div {\\n margin-left: 32px;\\n margin-bottom: 16px;\\n}\\n\\n.root {\\n -webkit-box-flex: 2;\\n flex: 2;\\n}\\n\\n.root .link {\\n margin-bottom: 36px;\\n}\\n\\n.root .link.primary {\\n font-weight: normal;\\n}\\n\\n.root section {\\n margin: 16px 0px 0px 0px;\\n}\\n\\n.root .title {\\n color: black;\\n font-size: 16px;\\n font-weight: bold;\\n -webkit-transition: color 0.1s ease-in;\\n transition: color 0.1s ease-in;\\n}\\n\\n.root .title.main {\\n color: #0072b5;\\n font-size: 24px;\\n}\\n\\n.root .title.secondary {\\n color: #ff9800;\\n font-size: 20px;\\n font-weight: bold;\\n}\\n\\n.root .title.other {\\n color: black;\\n font-size: 20px;\\n font-style: italic;\\n font-weight: normal;\\n}\\n\\n.no-content {\\n margin-left: 4px;\\n font-style: italic;\\n color: #696969;\\n}\\n\\n.accent {\\n color: #ff9800;\\n font-weight: bold;\\n}\\n\\n.accent:not(:last-child)::after {\\n content: \\\";\\\";\\n margin-left: -4px;\\n margin-right: 4px;\\n}\\n\\n.accent.black {\\n color: black;\\n}\\n\\n#citation-content span {\\n font-weight: bold;\\n}\\n\\n#citation-content span + span {\\n margin-left: 4px;\\n}\\n\\n.subitem:not(:last-child)::after {\\n content: \\\";\\\";\\n margin-left: -4px;\\n margin-right: 4px;\\n}\\n\\n.highlighted-section, #additional-details .collapse-body {\\n margin-top: 8px;\\n margin-left: 8px;\\n padding: 8px;\\n background-color: whitesmoke;\\n}\\n\\n.pill {\\n font-size: 16px;\\n color: #696969;\\n max-width: 20em;\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n margin-top: 4px;\\n}\\n\\n#additional-details .collapse-btn {\\n color: #0072b5;\\n cursor: pointer;\\n margin-bottom: 8px;\\n -webkit-transition: color 0.15s linear;\\n transition: color 0.15s linear;\\n}\\n\\n#additional-details .collapse-btn:hover {\\n color: #ff9800;\\n}\\n\\n#additional-details .collapse-body {\\n margin-left: 0px;\\n}\\n\\n.sidebar {\\n -webkit-box-flex: 1;\\n flex: 1;\\n margin-top: 16px;\\n}\\n\\n.sidebar:empty {\\n display: none;\\n}\\n\\n.sidebar section {\\n margin-bottom: 32px;\\n}\\n\\n.sidebar h6 {\\n font-size: 18px;\\n font-weight: bold;\\n color: #ff9800;\\n padding-bottom: 8px;\\n border-bottom: 1px solid #89b5ce;\\n}\\n\\n.sidebar .content {\\n display: block;\\n color: black;\\n margin-bottom: 8px;\\n}\\n\\n.with-separator:not(:last-child)::after {\\n content: \\\";\\\";\\n margin-right: 4px;\\n}\\n\\n.with-separator a {\\n margin-right: -4px;\\n}\\n\\n.with-separator2 {\\n font-style: italic;\\n font-size: 16px;\\n}\\n\\n.with-separator2:not(:last-child)::after {\\n content: \\\"|\\\";\\n margin-right: 4px;\\n}\\n\\n@media (max-width: 767.98px) {\\n #publication-container {\\n -webkit-box-orient: vertical !important;\\n -webkit-box-direction: normal !important;\\n flex-direction: column !important;\\n }\\n #publication-container > div {\\n padding: 16px 15px;\\n }\\n #publication-container p {\\n text-align: left;\\n }\\n\\n .breadcrumbs-header a {\\n margin-left: 15px;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/publication/components/publication-view/C:\\Projects\\openscience\\Portal.WebApplication/src\\publication\\components\\publication-view\\publication-view.component.scss","src/publication/components/publication-view/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/publication/components/publication-view/publication-view.component.scss","src/publication/components/publication-view/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAGA;EACE,YAAA;EACA,yBCJK;EDKL,mCAAA;EACA,sBAAA;EACA,4BAAA;EACA,2BAAA;AEFF;;AFKA;EACE,kBAAA;AEFF;;AFIE;EACE,iBAAA;EACA,mBAAA;AEFJ;;AFMA;EACE,mBAAA;UAAA,OAAA;AEHF;;AFKE;EACE,mBAAA;AEHJ;;AFME;EACE,mBAAA;AEJJ;;AFOE;EACE,wBAAA;AELJ;;AFQE;EACE,YC3BI;ED4BJ,eAAA;EACA,iBAAA;EACA,sCAAA;EAAA,8BAAA;AENJ;;AFQI;EACE,cC1CC;ED2CD,eAAA;AENN;;AFSI;EACE,cC3CG;ED4CH,eAAA;EACA,iBAAA;AEPN;;AFUI;EACE,YC5CE;ED6CF,eAAA;EACA,kBAAA;EACA,mBAAA;AERN;;AFaA;EACE,gBAAA;EACA,kBAAA;EACA,cAAA;AEVF;;AFaA;EACE,cChEO;EDiEP,iBAAA;AEVF;;AFYE;EACE,YAAA;EACA,iBAAA;EACA,iBAAA;AEVJ;;AFaE;EACE,YCrEI;AC0DR;;AFgBE;EACE,iBAAA;AEbJ;;AFgBE;EACE,gBAAA;AEdJ;;AFmBE;EACE,YAAA;EACA,iBAAA;EACA,iBAAA;AEhBJ;;AFoBA;EACE,eAAA;EACA,gBAAA;EACA,YAAA;EACA,4BAAA;AEjBF;;AFoBA;EACE,eAAA;EACA,cAAA;EACA,eAAA;EACA,gBAAA;EACA,uBAAA;EACA,mBAAA;EACA,eAAA;AEjBF;;AFqBE;EACE,cCvHG;EDwHH,eAAA;EACA,kBAAA;EACA,sCAAA;EAAA,8BAAA;AElBJ;;AFoBI;EACE,cCzHG;ACuGT;;AFsBE;EAEE,gBAAA;AErBJ;;AFyBA;EAKE,mBAAA;UAAA,OAAA;EACA,gBAAA;AE1BF;;AFqBE;EACE,aAAA;AEnBJ;;AFyBE;EACE,mBAAA;AEvBJ;;AF0BE;EACE,eAAA;EACA,iBAAA;EACA,cClJK;EDmJL,mBAAA;EACA,gCAAA;AExBJ;;AF2BE;EACE,cAAA;EACA,YCpJI;EDqJJ,kBAAA;AEzBJ;;AF8BE;EACE,YAAA;EACA,iBAAA;AE3BJ;;AF8BE;EACE,kBAAA;AE5BJ;;AFgCA;EACE,kBAAA;EACA,eAAA;AE7BF;;AF8BE;EACE,YAAA;EACA,iBAAA;AE5BJ;;AC9EI;EH+GF;IACE,uCAAA;IAAA,wCAAA;YAAA,iCAAA;EE7BF;EF+BE;IACE,kBAAA;EE7BJ;EFgCE;IACE,gBAAA;EE9BJ;;EFkCA;IACE,iBAAA;EE/BF;AACF","file":"src/publication/components/publication-view/publication-view.component.scss","sourcesContent":["@import '../../../variables';\r\n@import '../../../mixins.scss';\r\n\r\n.breadcrumbs-header {\r\n  height: 85px;\r\n  background-color: $primary;\r\n  background-image: url('../../../assets/img/home_2.jpg');\r\n  background-size: cover;\r\n  background-repeat: no-repeat;\r\n  background-position: center;\r\n}\r\n\r\n#publication-container {\r\n  margin-left: -32px;\r\n\r\n  &>div {\r\n    margin-left: 32px;\r\n    margin-bottom: 16px;\r\n  }\r\n}\r\n\r\n.root {\r\n  flex:2;\r\n\r\n  .link {\r\n    margin-bottom: 36px;\r\n  }\r\n\r\n  .link.primary {\r\n    font-weight: normal;\r\n  }\r\n\r\n  section {\r\n    margin: 16px 0px 0px 0px;\r\n  }\r\n\r\n  .title {\r\n    color: $black;\r\n    font-size: 16px;\r\n    font-weight: bold;\r\n    transition: color .1s ease-in;\r\n\r\n    &.main {\r\n      color: $primary;\r\n      font-size: 24px;\r\n    }\r\n\r\n    &.secondary {\r\n      color: $secondary;\r\n      font-size: 20px;\r\n      font-weight: bold;\r\n    }\r\n\r\n    &.other {\r\n      color: $black;\r\n      font-size: 20px;\r\n      font-style: italic;\r\n      font-weight: normal;\r\n    }\r\n  }\r\n}\r\n\r\n.no-content {\r\n  margin-left: 4px;\r\n  font-style: italic;\r\n  color: #696969;\r\n}\r\n\r\n.accent {\r\n  color: $secondary;\r\n  font-weight: bold;\r\n\r\n  &:not(:last-child)::after {\r\n    content: \";\";\r\n    margin-left: -4px;\r\n    margin-right: 4px;\r\n  }\r\n\r\n  &.black {\r\n    color: $black;\r\n  }\r\n}\r\n\r\n#citation-content {\r\n  span {\r\n    font-weight: bold;\r\n  }\r\n\r\n  span + span {\r\n    margin-left: 4px;\r\n  }\r\n}\r\n\r\n.subitem {\r\n  &:not(:last-child)::after {\r\n    content: \";\";\r\n    margin-left: -4px;\r\n    margin-right: 4px;\r\n  }\r\n}\r\n\r\n.highlighted-section {\r\n  margin-top: 8px;\r\n  margin-left: 8px;\r\n  padding: 8px;\r\n  background-color: whitesmoke;\r\n}\r\n\r\n.pill {\r\n  font-size: 16px;\r\n  color: #696969;\r\n  max-width: 20em;\r\n  overflow: hidden;\r\n  text-overflow: ellipsis;\r\n  white-space: nowrap;\r\n  margin-top: 4px;\r\n}\r\n\r\n#additional-details {\r\n  .collapse-btn {\r\n    color: $primary;\r\n    cursor: pointer;\r\n    margin-bottom: 8px;\r\n    transition: color .15s linear;\r\n\r\n    &:hover {\r\n      color: $secondary\r\n    }\r\n  }\r\n\r\n  .collapse-body {\r\n    @extend .highlighted-section;\r\n    margin-left: 0px;\r\n  }\r\n}\r\n\r\n.sidebar {\r\n  &:empty {\r\n    display: none;\r\n  }\r\n\r\n  flex: 1;\r\n  margin-top: 16px;\r\n\r\n  section {\r\n    margin-bottom: 32px;\r\n  }\r\n\r\n  h6{\r\n    font-size: 18px;\r\n    font-weight: bold;\r\n    color: $secondary;\r\n    padding-bottom: 8px;\r\n    border-bottom: 1px solid #89b5ce;\r\n  }\r\n\r\n  .content {\r\n    display: block;\r\n    color: $black;\r\n    margin-bottom: 8px;\r\n  }\r\n}\r\n\r\n.with-separator {\r\n  &:not(:last-child)::after {\r\n    content: \";\";\r\n    margin-right: 4px;\r\n  }\r\n\r\n  a {\r\n    margin-right: -4px;\r\n  }\r\n}\r\n\r\n.with-separator2 {\r\n  font-style: italic;\r\n  font-size: 16px;\r\n  &:not(:last-child)::after {\r\n    content: \"|\";\r\n    margin-right: 4px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"sm\"){\r\n  #publication-container {\r\n    flex-direction: column !important;\r\n\r\n    &>div {\r\n      padding: 16px 15px;\r\n    }\r\n\r\n    p {\r\n      text-align: left;\r\n    }\r\n  }\r\n\r\n  .breadcrumbs-header a{\r\n    margin-left: 15px;\r\n  }\r\n}\r\n","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;",".breadcrumbs-header {\n  height: 85px;\n  background-color: #0072b5;\n  background-image: url(\"../../../assets/img/home_2.jpg\");\n  background-size: cover;\n  background-repeat: no-repeat;\n  background-position: center;\n}\n\n#publication-container {\n  margin-left: -32px;\n}\n#publication-container > div {\n  margin-left: 32px;\n  margin-bottom: 16px;\n}\n\n.root {\n  flex: 2;\n}\n.root .link {\n  margin-bottom: 36px;\n}\n.root .link.primary {\n  font-weight: normal;\n}\n.root section {\n  margin: 16px 0px 0px 0px;\n}\n.root .title {\n  color: black;\n  font-size: 16px;\n  font-weight: bold;\n  transition: color 0.1s ease-in;\n}\n.root .title.main {\n  color: #0072b5;\n  font-size: 24px;\n}\n.root .title.secondary {\n  color: #ff9800;\n  font-size: 20px;\n  font-weight: bold;\n}\n.root .title.other {\n  color: black;\n  font-size: 20px;\n  font-style: italic;\n  font-weight: normal;\n}\n\n.no-content {\n  margin-left: 4px;\n  font-style: italic;\n  color: #696969;\n}\n\n.accent {\n  color: #ff9800;\n  font-weight: bold;\n}\n.accent:not(:last-child)::after {\n  content: \";\";\n  margin-left: -4px;\n  margin-right: 4px;\n}\n.accent.black {\n  color: black;\n}\n\n#citation-content span {\n  font-weight: bold;\n}\n#citation-content span + span {\n  margin-left: 4px;\n}\n\n.subitem:not(:last-child)::after {\n  content: \";\";\n  margin-left: -4px;\n  margin-right: 4px;\n}\n\n.highlighted-section, #additional-details .collapse-body {\n  margin-top: 8px;\n  margin-left: 8px;\n  padding: 8px;\n  background-color: whitesmoke;\n}\n\n.pill {\n  font-size: 16px;\n  color: #696969;\n  max-width: 20em;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n  margin-top: 4px;\n}\n\n#additional-details .collapse-btn {\n  color: #0072b5;\n  cursor: pointer;\n  margin-bottom: 8px;\n  transition: color 0.15s linear;\n}\n#additional-details .collapse-btn:hover {\n  color: #ff9800;\n}\n#additional-details .collapse-body {\n  margin-left: 0px;\n}\n\n.sidebar {\n  flex: 1;\n  margin-top: 16px;\n}\n.sidebar:empty {\n  display: none;\n}\n.sidebar section {\n  margin-bottom: 32px;\n}\n.sidebar h6 {\n  font-size: 18px;\n  font-weight: bold;\n  color: #ff9800;\n  padding-bottom: 8px;\n  border-bottom: 1px solid #89b5ce;\n}\n.sidebar .content {\n  display: block;\n  color: black;\n  margin-bottom: 8px;\n}\n\n.with-separator:not(:last-child)::after {\n  content: \";\";\n  margin-right: 4px;\n}\n.with-separator a {\n  margin-right: -4px;\n}\n\n.with-separator2 {\n  font-style: italic;\n  font-size: 16px;\n}\n.with-separator2:not(:last-child)::after {\n  content: \"|\";\n  margin-right: 4px;\n}\n\n@media (max-width: 767.98px) {\n  #publication-container {\n    flex-direction: column !important;\n  }\n  #publication-container > div {\n    padding: 16px 15px;\n  }\n  #publication-container p {\n    text-align: left;\n  }\n\n  .breadcrumbs-header a {\n    margin-left: 15px;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnInit } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { Publication } from '../../models/publication';\r\nimport { faFilePdf, faAngleLeft, faArrowLeft, faChevronLeft, faBackward, faTags, faTag, faInfoCircle } from '@fortawesome/free-solid-svg-icons';\r\nimport { scrollToTop } from 'src/infrastructure/utils';\r\nimport { SourceType } from 'src/publication/models/source-type.enum';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\n\r\n\r\n@Component({\r\n templateUrl: 'publication-view.component.html',\r\n styleUrls: ['publication-view.component.scss', '../../../common.scss']\r\n})\r\nexport class PublicationViewComponent implements OnInit {\r\n constructor(\r\n private router: Router,\r\n private route: ActivatedRoute,\r\n public locale: LocaleService\r\n ) {\r\n\r\n this.route.data.subscribe((data: { publication: Publication }) => this.publication = data.publication);\r\n }\r\n\r\n publication: Publication;\r\n faFilePdf = faFilePdf;\r\n bookmarkIcon = faTag;\r\n informationIcon = faInfoCircle;\r\n backToSearchIcon = faArrowLeft;//faChevronLeft;//faBackward;//faAngleLeft;\r\n showDetails = false;\r\n SourceType = SourceType;\r\n\r\n ngOnInit(): void {\r\n scrollToTop();\r\n }\r\n\r\n back() {\r\n if (window.history.state && window.history.state.navigationId && window.history.state.navigationId > 1)\r\n window.history.back();\r\n else\r\n this.router.navigate(['/search']);\r\n }\r\n}","export enum SourceType {\r\n national = 1,\r\n harvested = 2,\r\n wos = 3\r\n}","import { NgModule } from \"@angular/core\";\r\n\r\nimport { CommonModule } from '@angular/common';\r\nimport { HttpClientModule } from '@angular/common/http';\r\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n\r\nimport { PublicationViewComponent } from './components/publication-view/publication-view.component';\r\nimport { PublicationRouting } from './publication.routing';\r\nimport { PublicationViewResolverService } from './services/publication-view-resolver.service';\r\nimport { ComponentsModule } from 'src/components/components.module';\r\nimport { SharedModule } from 'src/shared/shared.module';\r\nimport { PublicationDetailsComponent } from './components/publication-details/publication-details.component';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n HttpClientModule,\r\n TranslateModule,\r\n FontAwesomeModule,\r\n ComponentsModule,\r\n SharedModule,\r\n PublicationRouting\r\n ],\r\n declarations: [\r\n PublicationViewComponent,\r\n PublicationDetailsComponent\r\n ],\r\n providers: [\r\n PublicationViewResolverService\r\n ]\r\n})\r\nexport class PublicationModule { }","import { NgModule } from '@angular/core';\r\nimport { RouterModule, Routes } from '@angular/router';\r\nimport { PublicationViewComponent } from './components/publication-view/publication-view.component';\r\nimport { PublicationViewResolverService } from './services/publication-view-resolver.service';\r\n\r\nconst routes: Routes = [\r\n {\r\n path: 'publication',\r\n children: [\r\n {\r\n path: ':id',\r\n children: [\r\n {\r\n path: '',\r\n component: PublicationViewComponent,\r\n resolve: {\r\n publication: PublicationViewResolverService\r\n },\r\n }\r\n ]\r\n }\r\n ]\r\n },\r\n];\r\n\r\n@NgModule({\r\n imports: [RouterModule.forChild(routes)],\r\n exports: [RouterModule],\r\n})\r\n\r\nexport class PublicationRouting { }","import { Injectable } from \"@angular/core\";\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { Resolve, ActivatedRouteSnapshot, RouterStateSnapshot, Router } from '@angular/router';\r\nimport { Publication } from '../models/publication';\r\nimport { of, EMPTY } from 'rxjs';\r\nimport { Configuration } from '../../infrastructure/configuration/configuration';\r\nimport { LoadingIndicatorService } from '../../infrastructure/loading-indicator.service';\r\nimport { take, mergeMap, catchError } from 'rxjs/operators';\r\nimport { urlRegex } from 'src/infrastructure/utils';\r\n\r\n@Injectable()\r\nexport class PublicationViewResolverService implements Resolve {\r\n constructor(\r\n private http: HttpClient,\r\n private router: Router,\r\n private config: Configuration,\r\n private loadingIndicator: LoadingIndicatorService,\r\n private sanitizer: DomSanitizer\r\n ) { }\r\n\r\n resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {\r\n let id = route.paramMap.get('id');\r\n this.loadingIndicator.start();\r\n return this.http\r\n .get(`${this.config.restUrl}/publication/${id}`)\r\n .pipe(\r\n take(1),\r\n catchError(err => of(null)),\r\n mergeMap(publication => {\r\n this.loadingIndicator.stop();\r\n if (publication) {\r\n if (publication.descriptions)\r\n publication.descriptions = publication.descriptions\r\n .flatMap((descriptions) => descriptions.split('\\n'));\r\n\r\n if (publication.files)\r\n publication.files.forEach(file => {\r\n file.safeUrl = this.sanitizer.bypassSecurityTrustUrl(`/api/FilesStorage?key=${file.key}&fileName=${file.name}&dbId=${file.dbId}`);\r\n });\r\n\r\n return of(publication);\r\n }\r\n else\r\n this.router.navigate(['notFound'])\r\n return EMPTY;\r\n })\r\n );\r\n }\r\n}","import { Component, OnInit } from '@angular/core';\r\nimport { scrollToTop } from 'src/infrastructure/utils';\r\nimport { InformationItem } from '../information/information-type';\r\nimport { faCaretRight } from '@fortawesome/free-solid-svg-icons';\r\nimport { PaginatorChangeEvent } from 'src/components/paginator/paginator.component';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\nimport { InformationResource } from '../information/information.resource';\r\nimport { faFile } from '@fortawesome/free-regular-svg-icons';\r\n\r\n\r\n@Component({\r\n selector: 'app-events',\r\n templateUrl: './events.component.html',\r\n styleUrls: ['../news-common-styles.scss']\r\n})\r\nexport class EventsComponent implements OnInit {\r\n\r\n constructor(\r\n public locale: LocaleService,\r\n private resource: InformationResource\r\n ) { }\r\n\r\n ngOnInit() {\r\n this.getData();\r\n }\r\n\r\n page = 0;\r\n pageSize = 6;\r\n totalCount = 0;\r\n items: InformationItem[] = [];\r\n\r\n linkIcon = faCaretRight;\r\n fileIcon = faFile;\r\n\r\n getData() {\r\n this.resource.getEvents(this.page, this.pageSize)\r\n .subscribe(({ totalCount, items }) => {\r\n this.items = items;\r\n this.totalCount = totalCount;\r\n scrollToTop();\r\n });\r\n }\r\n\r\n back() {\r\n window.history.back();\r\n }\r\n\r\n handlePageEvent(event: PaginatorChangeEvent) {\r\n this.page = event.page;\r\n this.pageSize = event.pageSize;\r\n this.getData();\r\n }\r\n}\r\n","module.exports = \".title {\\r\\n font-size: 19px;\\r\\n font-weight: bold;\\r\\n margin-bottom: 4px;\\r\\n}\\r\\n\\r\\n.date-container {\\r\\n font-size: 14px;\\r\\n font-style: italic;\\r\\n margin-bottom: 16px;\\r\\n}\\r\\n\\r\\n.content {\\r\\n overflow: hidden;\\r\\n margin-bottom: 1.2em;\\r\\n position: relative;\\r\\n}\\r\\n\\r\\n.content p {\\r\\n margin: 0;\\r\\n}\\r\\n\\r\\na {\\r\\n margin-bottom: 8px;\\r\\n word-break: break-all;\\r\\n}\\r\\n\\r\\n.show-more {\\r\\n color: #0072b5;\\r\\n font-weight: 600;\\r\\n\\r\\n width: -webkit-fit-content;\\r\\n\\r\\n width: -moz-fit-content;\\r\\n\\r\\n width: fit-content;\\r\\n position: absolute;\\r\\n bottom: 0;\\r\\n right: 0;\\r\\n z-index: 1400;\\r\\n\\r\\n padding-left: 10em;\\r\\n background-image : -webkit-gradient(linear, \\r\\n left top, right top, \\r\\n from(rgba(255,255,255, 0)), \\r\\n color-stop(70%, rgba(255,255,255, 1)));\\r\\n background-image : linear-gradient(to right, \\r\\n rgba(255,255,255, 0), \\r\\n rgba(255,255,255, 1) 70%);\\r\\n}\\r\\n\\r\\n.show-more > span:hover {\\r\\n cursor: pointer;\\r\\n color: #ff9800;\\r\\n}\\r\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9zZWFyY2gvY29tcG9uZW50cy9pbmZvcm1hdGlvbi9pbmZvcm1hdGlvbi1pdGVtL2luZm9ybWF0aW9uLWl0ZW0uY29tcG9uZW50LmNzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTtFQUNFLGVBQWU7RUFDZixpQkFBaUI7RUFDakIsa0JBQWtCO0FBQ3BCOztBQUVBO0VBQ0UsZUFBZTtFQUNmLGtCQUFrQjtFQUNsQixtQkFBbUI7QUFDckI7O0FBRUE7RUFDRSxnQkFBZ0I7RUFDaEIsb0JBQW9CO0VBQ3BCLGtCQUFrQjtBQUNwQjs7QUFFQTtFQUNFLFNBQVM7QUFDWDs7QUFFQTtFQUNFLGtCQUFrQjtFQUNsQixxQkFBcUI7QUFDdkI7O0FBRUE7RUFDRSxjQUFjO0VBQ2QsZ0JBQWdCOztFQUVoQiwwQkFBa0I7O0VBQWxCLHVCQUFrQjs7RUFBbEIsa0JBQWtCO0VBQ2xCLGtCQUFrQjtFQUNsQixTQUFTO0VBQ1QsUUFBUTtFQUNSLGFBQWE7O0VBRWIsa0JBQWtCO0VBQ2xCOzs7d0NBRXlCO0VBRnpCOzsyQkFFeUI7QUFDM0I7O0FBRUE7RUFDRSxlQUFlO0VBQ2YsY0FBYztBQUNoQiIsImZpbGUiOiJzcmMvc2VhcmNoL2NvbXBvbmVudHMvaW5mb3JtYXRpb24vaW5mb3JtYXRpb24taXRlbS9pbmZvcm1hdGlvbi1pdGVtLmNvbXBvbmVudC5jc3MiLCJzb3VyY2VzQ29udGVudCI6WyIudGl0bGUge1xyXG4gIGZvbnQtc2l6ZTogMTlweDtcclxuICBmb250LXdlaWdodDogYm9sZDtcclxuICBtYXJnaW4tYm90dG9tOiA0cHg7XHJcbn1cclxuXHJcbi5kYXRlLWNvbnRhaW5lciB7XHJcbiAgZm9udC1zaXplOiAxNHB4O1xyXG4gIGZvbnQtc3R5bGU6IGl0YWxpYztcclxuICBtYXJnaW4tYm90dG9tOiAxNnB4O1xyXG59XHJcblxyXG4uY29udGVudCB7XHJcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcclxuICBtYXJnaW4tYm90dG9tOiAxLjJlbTtcclxuICBwb3NpdGlvbjogcmVsYXRpdmU7XHJcbn1cclxuXHJcbi5jb250ZW50IHAge1xyXG4gIG1hcmdpbjogMDtcclxufVxyXG5cclxuYSB7XHJcbiAgbWFyZ2luLWJvdHRvbTogOHB4O1xyXG4gIHdvcmQtYnJlYWs6IGJyZWFrLWFsbDtcclxufVxyXG5cclxuLnNob3ctbW9yZSB7XHJcbiAgY29sb3I6ICMwMDcyYjU7XHJcbiAgZm9udC13ZWlnaHQ6IDYwMDtcclxuXHJcbiAgd2lkdGg6IGZpdC1jb250ZW50O1xyXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcclxuICBib3R0b206IDA7XHJcbiAgcmlnaHQ6IDA7XHJcbiAgei1pbmRleDogMTQwMDtcclxuXHJcbiAgcGFkZGluZy1sZWZ0OiAxMGVtO1xyXG4gIGJhY2tncm91bmQtaW1hZ2UgOiBsaW5lYXItZ3JhZGllbnQodG8gcmlnaHQsIFxyXG4gIHJnYmEoMjU1LDI1NSwyNTUsIDApLCBcclxuICByZ2JhKDI1NSwyNTUsMjU1LCAxKSA3MCUpO1xyXG59XHJcblxyXG4uc2hvdy1tb3JlID4gc3Bhbjpob3ZlciB7XHJcbiAgY3Vyc29yOiBwb2ludGVyO1xyXG4gIGNvbG9yOiAjZmY5ODAwO1xyXG59Il19 */\"","import { Component, Input, ViewChild, ElementRef, AfterViewInit, ChangeDetectorRef } from '@angular/core';\r\nimport { InformationItem } from '../information-type';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\nimport { faCaretRight } from '@fortawesome/free-solid-svg-icons';\r\nimport { faFile } from '@fortawesome/free-regular-svg-icons';\r\nimport { InformationType } from '../information-type.enum';\r\n\r\n@Component({\r\n selector: 'app-information-item',\r\n templateUrl: 'information-item.component.html',\r\n styleUrls: ['./information-item.component.css']\r\n})\r\n\r\nexport class InformationItemComponent implements AfterViewInit {\r\n @Input() item: InformationItem;\r\n @Input() section: any;\r\n\r\n @ViewChild('content', { static: true }) content: ElementRef;\r\n @ViewChild('para', { static: true }) para: ElementRef;\r\n\r\n InformationType = InformationType;\r\n faLinkIcon = faCaretRight;\r\n faFileIcon = faFile;\r\n\r\n maxHeight: string = '12.5em';\r\n\r\n constructor(\r\n public locale: LocaleService,\r\n public cd: ChangeDetectorRef\r\n ) { }\r\n\r\n ngAfterViewInit() {\r\n this.item.showMore = this.para.nativeElement.clientHeight > this.content.nativeElement.clientHeight;\r\n this.cd.detectChanges();\r\n }\r\n}","export enum InformationType {\r\n news = 1,\r\n course = 2,\r\n events = 3,\r\n document = 4\r\n}","module.exports = \".btn {\\n border-radius: 1px;\\n}\\n\\n.cursor-pointer {\\n cursor: pointer;\\n}\\n\\n.link {\\n text-decoration: underline;\\n color: #0072b5;\\n cursor: pointer;\\n -webkit-transition: color 0.1s ease-in;\\n transition: color 0.1s ease-in;\\n}\\n\\n.link:hover {\\n color: #002236;\\n}\\n\\n.link.primary {\\n color: #0072b5;\\n text-decoration: none;\\n font-weight: bold;\\n}\\n\\n.link.primary:hover {\\n color: #ff9800;\\n}\\n\\n.link-white {\\n color: #ffffff;\\n text-decoration: none;\\n font-weight: bold;\\n cursor: pointer;\\n -webkit-transition: color 0.1s ease-in;\\n transition: color 0.1s ease-in;\\n}\\n\\n.link-white:hover {\\n color: #ff9800;\\n}\\n\\n.badge {\\n padding: 4px 8px;\\n font-weight: normal;\\n border: 1px solid transparent;\\n border-radius: 2px;\\n}\\n\\n.badge {\\n margin-left: 4px;\\n}\\n\\n.badge.pill {\\n border-radius: 15px;\\n padding: 4px 10px;\\n}\\n\\n.badge.default {\\n border-color: #b4b4b4;\\n color: #696969;\\n font-style: italic;\\n}\\n\\n.badge.default:hover {\\n cursor: pointer;\\n color: #ff9800;\\n border-color: #ff9800;\\n}\\n\\n.badge.secondary-outlined {\\n border-color: #ff9800;\\n color: #e68900;\\n font-weight: bold;\\n}\\n\\n.badge.secondary-contained {\\n background-color: #ff9800;\\n color: black;\\n}\\n\\n.badge.primary-outlined {\\n border-color: #0072b5;\\n color: #0072b5;\\n font-weight: bold;\\n}\\n\\n.badge.primary-contained {\\n background-color: #0072b5;\\n color: #ffffff;\\n}\\n\\n.badge.creators-badge {\\n background-color: #696969;\\n color: #ffffff;\\n}\\n\\nsection {\\n margin-top: 42px;\\n margin-bottom: 42px;\\n width: 45%;\\n}\\n\\nsection .section-title {\\n font-size: 18px;\\n font-weight: bold;\\n color: #ff9800;\\n margin-bottom: 34px;\\n text-transform: uppercase;\\n text-align: left;\\n letter-spacing: initial;\\n}\\n\\nsection .items-container {\\n max-height: 650px;\\n overflow: auto;\\n position: relative;\\n padding-bottom: 32px;\\n overflow: -moz-scrollbars-none;\\n}\\n\\nsection .items-container {\\n -ms-overflow-style: none;\\n /* Internet Explorer 10+ */\\n scrollbar-width: none;\\n /* Firefox */\\n}\\n\\nsection .items-container::-webkit-scrollbar {\\n display: none;\\n /* Safari and Chrome */\\n}\\n\\nsection .overflow-fade-out {\\n position: absolute;\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-align: end;\\n align-items: flex-end;\\n bottom: 0;\\n width: 100%;\\n height: 100px;\\n background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0)), color-stop(70%, white));\\n background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0), white 70%);\\n}\\n\\nsection .overflow-fade-out a {\\n margin-bottom: 0px;\\n}\\n\\nsection a {\\n margin-bottom: 8px;\\n word-break: break-all;\\n}\\n\\n@media (max-width: 767.98px) {\\n section {\\n margin-top: 16px;\\n margin-bottom: 16px;\\n width: 90%;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/search/components/information/C:\\Projects\\openscience\\Portal.WebApplication/src\\search\\components\\information\\information.component.scss","src/search/components/information/information.component.scss","src/search/components/information/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/search/components/information/C:\\Projects\\openscience\\Portal.WebApplication/stdin","src/search/components/information/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAEA;EACE,kBAAA;ACDF;;ADIA;EACE,eAAA;ACDF;;ADIA;EACE,0BAAA;EACA,cEXK;EFYL,eAAA;EACA,sCAAA;EAAA,8BAAA;ACDF;;ADGE;EACE,cAAA;ACDJ;;ADIE;EACE,cEpBG;EFqBH,qBAAA;EACA,iBAAA;ACFJ;;ADII;EACE,cErBG;ADmBT;;ADOA;EACE,cEzBM;EF0BN,qBAAA;EACA,iBAAA;EACA,eAAA;EACA,sCAAA;EAAA,8BAAA;ACJF;;ADME;EACE,cElCK;AD8BT;;ADQA;EACE,gBAAA;EACA,mBAAA;EACA,6BAAA;EACA,kBAAA;ACLF;;ADOE;EACE,gBAAA;ACLJ;;ADQE;EACE,mBAAA;EACA,iBAAA;ACNJ;;ADSE;EACE,qBEnDG;EFoDH,cEnDK;EFoDL,kBAAA;ACPJ;;ADSI;EACE,eAAA;EACA,cE5DG;EF6DH,qBE7DG;ADsDT;;ADWE;EACE,qBElEK;EFmEL,cAAA;EACA,iBAAA;ACTJ;;ADYE;EACE,yBExEK;EFyEL,YEpEI;AD0DR;;ADaE;EACE,qBEjFG;EFkFH,cElFG;EFmFH,iBAAA;ACXJ;;ADcE;EACE,yBEvFG;EFwFH,cElFI;ADsER;;ADeE;EACE,yBEpFK;EFqFL,cEvFI;AD0ER;;AE7EA;EACE,gBAAA;EACA,mBAAA;EACA,UAAA;AFgFF;;AE9EE;EACE,eAAA;EACA,iBAAA;EACA,cDPK;ECQL,mBAAA;EACA,yBAAA;EACA,gBAAA;EACA,uBAAA;AFgFJ;;AE7EE;EACE,iBAAA;EACA,cAAA;EACA,kBAAA;EACA,oBAAA;EACA,8BAAA;AF+EJ;;AE5EE;EACE,wBAAA;EAA2B,0BAAA;EAC3B,qBAAA;EAAwB,YAAA;AFgF5B;;AE7EE;EACE,aAAA;EAAgB,sBAAA;AFgFpB;;AE7EE;EACE,kBAAA;EACA,oBAAA;EAAA,aAAA;EACA,sBAAA;UAAA,qBAAA;EACA,SAAA;EACA,WAAA;EACA,aAAA;EACA,uHAAA;EAAA,+EAAA;AF+EJ;;AE3EI;EACE,kBAAA;AF6EN;;AEzEE;EACE,kBAAA;EACA,qBAAA;AF2EJ;;AGxDI;EDdF;IACE,gBAAA;IACA,mBAAA;IACA,UAAA;EF0EF;AACF","file":"src/search/components/information/information.component.scss","sourcesContent":["@import \"./variables.scss\";\r\n\r\n.btn {\r\n  border-radius: 1px;\r\n}\r\n\r\n.cursor-pointer {\r\n  cursor: pointer;\r\n}\r\n\r\n.link {\r\n  text-decoration: underline;\r\n  color: $primary;\r\n  cursor: pointer;\r\n  transition: color .1s ease-in;\r\n\r\n  &:hover {\r\n    color: darken($color: $primary, $amount: 25%);\r\n  }\r\n\r\n  &.primary {\r\n    color: $primary;\r\n    text-decoration: none;\r\n    font-weight: bold;\r\n\r\n    &:hover {\r\n      color: $secondary;\r\n    }\r\n  }\r\n}\r\n\r\n.link-white {\r\n  color: $white;\r\n  text-decoration: none;\r\n  font-weight: bold;\r\n  cursor: pointer;\r\n  transition: color .1s ease-in;\r\n\r\n  &:hover {\r\n    color: $secondary;\r\n  }\r\n}\r\n\r\n.badge {\r\n  padding: 4px 8px;\r\n  font-weight: normal;\r\n  border: 1px solid transparent;\r\n  border-radius: 2px;\r\n\r\n  & {\r\n    margin-left: 4px;\r\n  }\r\n\r\n  &.pill {\r\n    border-radius: 15px;\r\n    padding: 4px 10px;\r\n  }\r\n\r\n  &.default {\r\n    border-color: $gray;\r\n    color: $normal;\r\n    font-style: italic;\r\n\r\n    &:hover {\r\n      cursor: pointer;\r\n      color: $secondary;\r\n      border-color: $secondary;\r\n    }\r\n  }\r\n\r\n  &.secondary-outlined {\r\n    border-color: $secondary;\r\n    color: darken($secondary, 5%);\r\n    font-weight: bold;\r\n  }\r\n\r\n  &.secondary-contained {\r\n    background-color: $secondary;\r\n    color: $black;\r\n  }\r\n\r\n  &.primary-outlined {\r\n    border-color: $primary;\r\n    color: $primary;\r\n    font-weight: bold;\r\n  }\r\n\r\n  &.primary-contained {\r\n    background-color: $primary;\r\n    color: $white;\r\n  }\r\n\r\n  &.creators-badge {\r\n    background-color: $normal;\r\n    color: $white;\r\n  }\r\n}",".btn {\n  border-radius: 1px;\n}\n\n.cursor-pointer {\n  cursor: pointer;\n}\n\n.link {\n  text-decoration: underline;\n  color: #0072b5;\n  cursor: pointer;\n  transition: color 0.1s ease-in;\n}\n.link:hover {\n  color: #002236;\n}\n.link.primary {\n  color: #0072b5;\n  text-decoration: none;\n  font-weight: bold;\n}\n.link.primary:hover {\n  color: #ff9800;\n}\n\n.link-white {\n  color: #ffffff;\n  text-decoration: none;\n  font-weight: bold;\n  cursor: pointer;\n  transition: color 0.1s ease-in;\n}\n.link-white:hover {\n  color: #ff9800;\n}\n\n.badge {\n  padding: 4px 8px;\n  font-weight: normal;\n  border: 1px solid transparent;\n  border-radius: 2px;\n}\n.badge {\n  margin-left: 4px;\n}\n.badge.pill {\n  border-radius: 15px;\n  padding: 4px 10px;\n}\n.badge.default {\n  border-color: #b4b4b4;\n  color: #696969;\n  font-style: italic;\n}\n.badge.default:hover {\n  cursor: pointer;\n  color: #ff9800;\n  border-color: #ff9800;\n}\n.badge.secondary-outlined {\n  border-color: #ff9800;\n  color: #e68900;\n  font-weight: bold;\n}\n.badge.secondary-contained {\n  background-color: #ff9800;\n  color: black;\n}\n.badge.primary-outlined {\n  border-color: #0072b5;\n  color: #0072b5;\n  font-weight: bold;\n}\n.badge.primary-contained {\n  background-color: #0072b5;\n  color: #ffffff;\n}\n.badge.creators-badge {\n  background-color: #696969;\n  color: #ffffff;\n}\n\nsection {\n  margin-top: 42px;\n  margin-bottom: 42px;\n  width: 45%;\n}\nsection .section-title {\n  font-size: 18px;\n  font-weight: bold;\n  color: #ff9800;\n  margin-bottom: 34px;\n  text-transform: uppercase;\n  text-align: left;\n  letter-spacing: initial;\n}\nsection .items-container {\n  max-height: 650px;\n  overflow: auto;\n  position: relative;\n  padding-bottom: 32px;\n  overflow: -moz-scrollbars-none;\n}\nsection .items-container {\n  -ms-overflow-style: none;\n  /* Internet Explorer 10+ */\n  scrollbar-width: none;\n  /* Firefox */\n}\nsection .items-container::-webkit-scrollbar {\n  display: none;\n  /* Safari and Chrome */\n}\nsection .overflow-fade-out {\n  position: absolute;\n  display: flex;\n  align-items: flex-end;\n  bottom: 0;\n  width: 100%;\n  height: 100px;\n  background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0), white 70%);\n}\nsection .overflow-fade-out a {\n  margin-bottom: 0px;\n}\nsection a {\n  margin-bottom: 8px;\n  word-break: break-all;\n}\n\n@media (max-width: 767.98px) {\n  section {\n    margin-top: 16px;\n    margin-bottom: 16px;\n    width: 90%;\n  }\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","@import '../../../variables';\r\n@import '../../../common';\r\n@import '../../../mixins';\r\n\r\nsection {\r\n  margin-top: 42px;\r\n  margin-bottom: 42px;\r\n  width: 45%;\r\n\r\n  .section-title {\r\n    font-size: 18px;\r\n    font-weight: bold;\r\n    color: $secondary;\r\n    margin-bottom: 34px;\r\n    text-transform: uppercase;\r\n    text-align: left;\r\n    letter-spacing: initial;\r\n  }\r\n\r\n  .items-container {\r\n    max-height: 650px;\r\n    overflow: auto;\r\n    position: relative;\r\n    padding-bottom: 32px;\r\n    overflow: -moz-scrollbars-none;\r\n  }\r\n\r\n  .items-container {\r\n    -ms-overflow-style: none;  /* Internet Explorer 10+ */\r\n    scrollbar-width: none;  /* Firefox */\r\n  }\r\n\r\n  .items-container::-webkit-scrollbar { \r\n    display: none;  /* Safari and Chrome */\r\n  }\r\n\r\n  .overflow-fade-out {\r\n    position: absolute;\r\n    display: flex;\r\n    align-items: flex-end;\r\n    bottom: 0;\r\n    width: 100%;\r\n    height: 100px;\r\n    background-image : linear-gradient(to bottom, \r\n                    rgba(255,255,255, 0), \r\n                    rgba(255,255,255, 1) 70%);\r\n\r\n    a {\r\n      margin-bottom: 0px;\r\n    }\r\n  }\r\n\r\n  a {\r\n    margin-bottom: 8px;\r\n    word-break: break-all;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"sm\"){\r\n  section {\r\n    margin-top: 16px;\r\n    margin-bottom: 16px;\r\n    width: 90%;\r\n  }\r\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnInit } from '@angular/core';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { getPaginatedNews, getPaginatedEvents } from './information-data-mock';\r\nimport { urlRegex } from 'src/infrastructure/utils';\r\nimport { InformationItem } from './information-type';\r\nimport { InformationType } from './information-type.enum';\r\nimport { faAngleDown } from '@fortawesome/free-solid-svg-icons';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\nimport { InformationResource } from './information.resource';\r\n\r\n\r\n@Component({\r\n selector: 'information',\r\n templateUrl: './information.component.html',\r\n styleUrls: ['./information.component.scss']\r\n})\r\nexport class InformationComponent implements OnInit {\r\n news: InformationItem[] = [];\r\n events: InformationItem[] = [];\r\n courses: InformationItem[] = [];\r\n documents: InformationItem[] = [];\r\n sections = [];\r\n InformationType = InformationType;\r\n faAngleDown = faAngleDown;\r\n\r\n\r\n constructor(\r\n private sanitizer: DomSanitizer,\r\n public locale: LocaleService,\r\n private resource: InformationResource\r\n ) {\r\n }\r\n\r\n ngOnInit() {\r\n this.resource.getNews(0, 5)\r\n .subscribe(({ items }) => {\r\n this.sections[0] = {\r\n type: InformationType.news,\r\n data: items.map(item => this.processResources(item))\r\n }\r\n });\r\n\r\n this.resource.getEvents(0, 6)\r\n .subscribe(({ items }) => {\r\n this.sections[1] = {\r\n type: InformationType.events,\r\n data: items.map(item => this.processResources(item))\r\n }\r\n });\r\n }\r\n\r\n processResources(item: InformationItem) {\r\n item.resourcesSafe = item.resources\r\n .map(resource => {\r\n if (resource.url.trim().match(urlRegex))\r\n return {\r\n name: resource.name,\r\n url: this.sanitizer.bypassSecurityTrustUrl(resource.url.trim())\r\n };\r\n else\r\n return null;\r\n })\r\n .filter(resource => resource);\r\n\r\n return item;\r\n }\r\n}\r\n","import { Injectable } from \"@angular/core\";\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\nimport { InformationItem } from './information-type';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class InformationResource {\r\n\r\n constructor(\r\n private config: Configuration,\r\n private http: HttpClient\r\n ) { }\r\n\r\n getNews(page, pageSize) {\r\n let url = `${this.config.restUrl}/information/news?limit=${pageSize}&offset=${page * pageSize}`;\r\n return this.http.get<{ items: InformationItem[], totalCount: number }>(url);\r\n }\r\n\r\n getEvents(page, pageSize) {\r\n let url = `${this.config.restUrl}/information/events?limit=${pageSize}&offset=${page * pageSize}`;\r\n return this.http.get<{ items: InformationItem[], totalCount: number }>(url);\r\n }\r\n}","module.exports = \"\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJzcmMvc2VhcmNoL2NvbXBvbmVudHMvbGFuZGluZy1wYWdlL2xhbmRpbmctcGFnZS5jb21wb25lbnQuc2NzcyJ9 */\"","import { Component } from '@angular/core';\r\n\r\n@Component({\r\n templateUrl: './landing-page.component.html',\r\n styleUrls: ['./landing-page.component.scss']\r\n})\r\nexport class LandingPageComponent { }\r\n","module.exports = \".breadcrumbs-header {\\n height: 85px;\\n background-color: #0072b5;\\n background-image: url('home_2.jpg');\\n background-size: cover;\\n background-repeat: no-repeat;\\n background-position: center;\\n}\\n.breadcrumbs-header .container {\\n margin-top: initial;\\n}\\na.link {\\n font-weight: normal;\\n}\\n.link.long {\\n word-break: break-all;\\n}\\n.link.bold {\\n font-weight: bold;\\n}\\n.container {\\n padding: 0px 32px;\\n margin-top: 60px;\\n}\\n.information-piece {\\n border: 1px solid black;\\n}\\n.title {\\n color: #0072b5;\\n font-size: 26px;\\n font-weight: bold;\\n}\\n.subtitle {\\n color: #ff9800;\\n font-size: 18px;\\n font-weight: bold;\\n text-transform: uppercase;\\n margin: 32px 0px;\\n}\\n.sub-sub-title {\\n color: #0072b5;\\n font-weight: bold;\\n font-size: 16px;\\n margin-bottom: 2px;\\n}\\n.date-container {\\n font-size: 14px;\\n font-style: italic;\\n margin-bottom: 16px;\\n}\\n.document-box {\\n padding: 8px;\\n background-color: whitesmoke;\\n}\\n.document-box fa-icon {\\n margin-right: 4px;\\n}\\n@media (max-width: 575.98px) {\\n .container p,\\n.container li,\\n.container h1,\\n.container h2,\\n.container a {\\n text-align: left;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/search/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\search\\components\\news-common-styles.scss","src/search/components/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/search/components/news-common-styles.scss","src/search/components/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAGA;EACE,YAAA;EACA,yBCJK;EDKL,mCAAA;EACA,sBAAA;EACA,4BAAA;EACA,2BAAA;AEFF;AFIE;EACE,mBAAA;AEFJ;AFMA;EACE,mBAAA;AEHF;AFMA;EACE,qBAAA;AEHF;AFMA;EACE,iBAAA;AEHF;AFMA;EACE,iBAAA;EACA,gBAAA;AEHF;AFMA;EACE,uBAAA;AEHF;AFMA;EACE,cCrCK;EDsCL,eAAA;EACA,iBAAA;AEHF;AFMA;EACE,cCvCO;EDwCP,eAAA;EACA,iBAAA;EACA,yBAAA;EACA,gBAAA;AEHF;AFMA;EACE,cCnDK;EDoDL,iBAAA;EACA,eAAA;EACA,kBAAA;AEHF;AFMA;EACE,eAAA;EACA,kBAAA;EACA,mBAAA;AEHF;AFMA;EACE,YAAA;EACA,4BAAA;AEHF;AFKE;EACE,iBAAA;AEHJ;ACOI;EHEA;;;;;IAKE,gBAAA;EELJ;AACF","file":"src/search/components/news-common-styles.scss","sourcesContent":["@import '../../variables';\r\n@import '../../mixins';\r\n\r\n.breadcrumbs-header {\r\n  height: 85px;\r\n  background-color: $primary;\r\n  background-image: url('../../assets/img/home_2.jpg');\r\n  background-size: cover;\r\n  background-repeat: no-repeat;\r\n  background-position: center;\r\n\r\n  .container {\r\n    margin-top: initial;\r\n  }\r\n}\r\n\r\na.link {\r\n  font-weight: normal;\r\n}\r\n\r\n.link.long {\r\n  word-break: break-all;\r\n}\r\n\r\n.link.bold {\r\n  font-weight: bold;\r\n}\r\n\r\n.container  {\r\n  padding: 0px 32px;\r\n  margin-top: 60px;\r\n}\r\n\r\n.information-piece {\r\n  border: 1px solid black;\r\n}\r\n\r\n.title {\r\n  color: $primary;\r\n  font-size: 26px;\r\n  font-weight: bold;\r\n}\r\n\r\n.subtitle {\r\n  color: $secondary;\r\n  font-size: 18px;\r\n  font-weight: bold;\r\n  text-transform: uppercase;\r\n  margin: 32px 0px;\r\n}\r\n\r\n.sub-sub-title {\r\n  color: $primary;\r\n  font-weight: bold;\r\n  font-size: 16px;\r\n  margin-bottom: 2px;\r\n}\r\n\r\n.date-container {\r\n  font-size: 14px;\r\n  font-style: italic;\r\n  margin-bottom: 16px;\r\n}\r\n\r\n.document-box {\r\n  padding: 8px;\r\n  background-color: whitesmoke;\r\n\r\n  fa-icon {\r\n    margin-right: 4px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"xs\"){\r\n  .container {  \r\n    p,\r\n    li,\r\n    h1,\r\n    h2,\r\n    a {\r\n      text-align: left;\r\n    }\r\n  }\r\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;",".breadcrumbs-header {\n  height: 85px;\n  background-color: #0072b5;\n  background-image: url(\"../../assets/img/home_2.jpg\");\n  background-size: cover;\n  background-repeat: no-repeat;\n  background-position: center;\n}\n.breadcrumbs-header .container {\n  margin-top: initial;\n}\n\na.link {\n  font-weight: normal;\n}\n\n.link.long {\n  word-break: break-all;\n}\n\n.link.bold {\n  font-weight: bold;\n}\n\n.container {\n  padding: 0px 32px;\n  margin-top: 60px;\n}\n\n.information-piece {\n  border: 1px solid black;\n}\n\n.title {\n  color: #0072b5;\n  font-size: 26px;\n  font-weight: bold;\n}\n\n.subtitle {\n  color: #ff9800;\n  font-size: 18px;\n  font-weight: bold;\n  text-transform: uppercase;\n  margin: 32px 0px;\n}\n\n.sub-sub-title {\n  color: #0072b5;\n  font-weight: bold;\n  font-size: 16px;\n  margin-bottom: 2px;\n}\n\n.date-container {\n  font-size: 14px;\n  font-style: italic;\n  margin-bottom: 16px;\n}\n\n.document-box {\n  padding: 8px;\n  background-color: whitesmoke;\n}\n.document-box fa-icon {\n  margin-right: 4px;\n}\n\n@media (max-width: 575.98px) {\n  .container p,\n.container li,\n.container h1,\n.container h2,\n.container a {\n    text-align: left;\n  }\n}","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnInit } from '@angular/core';\r\nimport { InformationItem } from '../information/information-type';\r\nimport { getPaginatedNews } from '../information/information-data-mock';\r\nimport { faPaperclip, faCaretRight } from '@fortawesome/free-solid-svg-icons';\r\nimport { scrollToTop } from 'src/infrastructure/utils';\r\nimport { PaginatorChangeEvent } from 'src/components/paginator/paginator.component';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\nimport { InformationResource } from '../information/information.resource';\r\nimport { faFile } from '@fortawesome/free-regular-svg-icons';\r\n\r\n@Component({\r\n selector: 'app-news',\r\n templateUrl: './news.component.html',\r\n styleUrls: ['../news-common-styles.scss']\r\n})\r\nexport class NewsComponent implements OnInit {\r\n constructor(\r\n public locale: LocaleService,\r\n private resource: InformationResource\r\n ) { }\r\n\r\n ngOnInit() {\r\n this.getData();\r\n }\r\n\r\n page = 0;\r\n pageSize = 6;\r\n totalCount = 0;\r\n items: InformationItem[] = [];\r\n\r\n linkIcon = faCaretRight;\r\n fileIcon = faFile;\r\n\r\n getData() {\r\n this.resource.getNews(this.page, this.pageSize)\r\n .subscribe(({ totalCount, items }) => {\r\n this.items = items;\r\n this.totalCount = totalCount;\r\n scrollToTop();\r\n });\r\n }\r\n\r\n back() {\r\n window.history.back();\r\n }\r\n\r\n handlePageEvent(event: PaginatorChangeEvent) {\r\n this.page = event.page;\r\n this.pageSize = event.pageSize;\r\n this.getData();\r\n }\r\n}\r\n","module.exports = \"#categories {\\n margin-top: -59px;\\n}\\n#categories .loading {\\n position: relative;\\n}\\n#categories .loading .placeholder {\\n position: absolute;\\n top: 0;\\n right: 0;\\n bottom: 0;\\n left: 0;\\n background-color: #f9f5f5;\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-orient: vertical;\\n -webkit-box-direction: normal;\\n flex-direction: column;\\n -webkit-box-pack: justify;\\n justify-content: space-between;\\n -webkit-box-align: center;\\n align-items: center;\\n}\\n#categories .loading .placeholder div {\\n width: 85%;\\n margin: 16px auto;\\n height: 50px;\\n background-color: #e2e2e2;\\n border-radius: 8px;\\n}\\n#categories .category {\\n width: 31.5%;\\n margin-bottom: 24px;\\n}\\n#categories .category .category-header {\\n height: 60px;\\n padding-left: 30px;\\n background: whitesmoke;\\n background: linear-gradient(145deg, snow 50%, #f7f3f3 100%);\\n border-top-left-radius: 8px;\\n border-top-right-radius: 8px;\\n font-weight: bold;\\n font-size: 18px;\\n}\\n#categories .category .category-root {\\n line-height: 2.25;\\n padding: 10px 12px;\\n box-shadow: 3px 3px 10px 0px whitesmoke;\\n border: 1px solid whitesmoke;\\n border-bottom-left-radius: 8px;\\n border-bottom-right-radius: 8px;\\n min-height: 250px;\\n}\\n#categories .category .category-root .link {\\n margin-left: 16px !important;\\n}\\n#categories .category .category-item {\\n padding: 4px 16px;\\n border-radius: 8px;\\n color: black;\\n}\\n#categories .category .category-item:hover {\\n cursor: pointer;\\n background: whitesmoke;\\n background: linear-gradient(145deg, snow 50%, #f7f3f3 100%);\\n}\\n#categories .category .category-item .contain-text {\\n display: inline-block;\\n max-width: 100%;\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n}\\n@media (max-width: 1199.98px) {\\n #categories .category {\\n width: 48%;\\n }\\n}\\n@media (max-width: 991.98px) {\\n #categories {\\n font-size: 14px;\\n }\\n\\n h3 {\\n font-size: 20px;\\n }\\n}\\n@media (max-width: 767.98px) {\\n #categories .category {\\n width: 90%;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/search/components/search-categories/C:\\Projects\\openscience\\Portal.WebApplication/src\\search\\components\\search-categories\\search-categories.component.scss","src/search/components/search-categories/search-categories.component.scss","src/search/components/search-categories/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/search/components/search-categories/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAGA;EACE,iBAAA;ACFF;ADIE;EACE,kBAAA;ACFJ;ADGI;EACE,kBAAA;EACA,MAAA;EACA,QAAA;EACA,SAAA;EACA,OAAA;EACA,yBAAA;EACA,oBAAA;EAAA,aAAA;EACA,4BAAA;EAAA,6BAAA;UAAA,sBAAA;EACA,yBAAA;UAAA,8BAAA;EACA,yBAAA;UAAA,mBAAA;ACDN;ADGM;EACE,UAAA;EACA,iBAAA;EACA,YAAA;EACA,yBAAA;EACA,kBAAA;ACDR;ADME;EACE,YAAA;EACA,mBAAA;ACJJ;ADMI;EACE,YAAA;EACA,kBAAA;EACA,sBAAA;EACA,2DAAA;EACA,2BAAA;EACA,4BAAA;EACA,iBAAA;EACA,eAAA;ACJN;ADOI;EACE,iBAAA;EACA,kBAAA;EACA,uCAAA;EACA,4BAAA;EACA,8BAAA;EACA,+BAAA;EACA,iBAAA;ACLN;ADOM;EACE,4BAAA;ACLR;ADSI;EACE,iBAAA;EACA,kBAAA;EACA,YEpDE;AD6CR;ADSM;EACE,eAAA;EACA,sBAAA;EACA,2DAAA;ACPR;ADUM;EACE,qBAAA;EACA,eAAA;EACA,gBAAA;EACA,uBAAA;EACA,mBAAA;ACRR;AEMI;EHUA;IACE,UAAA;ECZJ;AACF;AEAI;EHiBF;IACE,eAAA;ECdF;;EDiBA;IACE,eAAA;ECdF;AACF;AETI;EH4BA;IACE,UAAA;EChBJ;AACF","file":"src/search/components/search-categories/search-categories.component.scss","sourcesContent":["@import '../../../variables';\r\n@import '../../../mixins';\r\n\r\n#categories {\r\n  margin-top: -59px;\r\n\r\n  .loading {\r\n    position: relative;\r\n    .placeholder {\r\n      position: absolute;\r\n      top: 0;\r\n      right: 0;\r\n      bottom: 0;\r\n      left: 0;\r\n      background-color: #f9f5f5;\r\n      display: flex;\r\n      flex-direction: column;\r\n      justify-content: space-between;\r\n      align-items: center;\r\n\r\n      div {\r\n        width: 85%;\r\n        margin: 16px auto;\r\n        height: 50px;\r\n        background-color: #e2e2e2;\r\n        border-radius: 8px;\r\n      }\r\n    }\r\n  }\r\n\r\n  .category {\r\n    width: 31.5%;\r\n    margin-bottom: 24px;\r\n\r\n    .category-header {\r\n      height: 60px;\r\n      padding-left: 30px;\r\n      background: whitesmoke;\r\n      background: linear-gradient(145deg, rgba(255,250,250,1) 50%, rgba(247,243,243,1) 100%);\r\n      border-top-left-radius: 8px;\r\n      border-top-right-radius: 8px;\r\n      font-weight: bold;\r\n      font-size: 18px;\r\n    }\r\n\r\n    .category-root {\r\n      line-height: 2.25;\r\n      padding: 10px 12px;\r\n      box-shadow:  3px 3px 10px 0px whitesmoke;\r\n      border: 1px solid whitesmoke;\r\n      border-bottom-left-radius: 8px;\r\n      border-bottom-right-radius: 8px;\r\n      min-height: 250px;\r\n\r\n      .link {\r\n        margin-left: 16px !important;\r\n      }\r\n    }\r\n\r\n    .category-item {\r\n      padding: 4px 16px;\r\n      border-radius: 8px;\r\n      color: $black;\r\n\r\n      &:hover {\r\n        cursor: pointer;\r\n        background: whitesmoke;\r\n        background: linear-gradient(145deg, rgba(255,250,250,1) 50%, rgba(247,243,243,1) 100%);\r\n      }\r\n\r\n      .contain-text {\r\n        display: inline-block;\r\n        max-width: 100%;\r\n        overflow: hidden;\r\n        text-overflow: ellipsis;\r\n        white-space: nowrap;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"lg\") { \r\n  #categories {\r\n    .category {\r\n      width: 48%;\r\n    }\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"md\") { \r\n  #categories {\r\n    font-size: 14px;\r\n  }\r\n\r\n  h3 {\r\n    font-size: 20px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"sm\") { \r\n  #categories {\r\n    .category {\r\n      width: 90%;\r\n    }\r\n  }\r\n}","#categories {\n  margin-top: -59px;\n}\n#categories .loading {\n  position: relative;\n}\n#categories .loading .placeholder {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  background-color: #f9f5f5;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  align-items: center;\n}\n#categories .loading .placeholder div {\n  width: 85%;\n  margin: 16px auto;\n  height: 50px;\n  background-color: #e2e2e2;\n  border-radius: 8px;\n}\n#categories .category {\n  width: 31.5%;\n  margin-bottom: 24px;\n}\n#categories .category .category-header {\n  height: 60px;\n  padding-left: 30px;\n  background: whitesmoke;\n  background: linear-gradient(145deg, snow 50%, #f7f3f3 100%);\n  border-top-left-radius: 8px;\n  border-top-right-radius: 8px;\n  font-weight: bold;\n  font-size: 18px;\n}\n#categories .category .category-root {\n  line-height: 2.25;\n  padding: 10px 12px;\n  box-shadow: 3px 3px 10px 0px whitesmoke;\n  border: 1px solid whitesmoke;\n  border-bottom-left-radius: 8px;\n  border-bottom-right-radius: 8px;\n  min-height: 250px;\n}\n#categories .category .category-root .link {\n  margin-left: 16px !important;\n}\n#categories .category .category-item {\n  padding: 4px 16px;\n  border-radius: 8px;\n  color: black;\n}\n#categories .category .category-item:hover {\n  cursor: pointer;\n  background: whitesmoke;\n  background: linear-gradient(145deg, snow 50%, #f7f3f3 100%);\n}\n#categories .category .category-item .contain-text {\n  display: inline-block;\n  max-width: 100%;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n\n@media (max-width: 1199.98px) {\n  #categories .category {\n    width: 48%;\n  }\n}\n@media (max-width: 991.98px) {\n  #categories {\n    font-size: 14px;\n  }\n\n  h3 {\n    font-size: 20px;\n  }\n}\n@media (max-width: 767.98px) {\n  #categories .category {\n    width: 90%;\n  }\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnInit } from '@angular/core';\r\nimport { SearchFieldType, SearchFieldCategories } from 'src/search/models/search-field-type.enum';\r\nimport { SearchResource } from 'src/search/services/search.resource';\r\nimport { SEARCH_FIELD_SPEC } from '../../models/search-field-type-spec';\r\nimport { Router } from '@angular/router';\r\nimport { LoadingIndicatorService } from 'src/infrastructure/loading-indicator.service';\r\nimport { SearchField } from 'src/search/models/search-field';\r\nimport * as QueryBuilder from 'src/search/services/logical-operator-query-builder.service';\r\nimport { SearchState } from 'src/search/services/search.state';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Component({\r\n selector: 'search-categories',\r\n templateUrl: './search-categories.component.html',\r\n styleUrls: ['./search-categories.component.scss']\r\n})\r\nexport class SearchCategoriesComponent implements OnInit {\r\n\r\n constructor(\r\n private resource: SearchResource,\r\n private router: Router,\r\n private loadingIndicator: LoadingIndicatorService,\r\n private state: SearchState\r\n ) {\r\n this.loading = this.loadingIndicator.change$;\r\n }\r\n\r\n categoryData: any = {};\r\n SEARCH_FIELD_SPEC = SEARCH_FIELD_SPEC;\r\n SearchFieldType = SearchFieldType;\r\n categories = SearchFieldCategories;\r\n loading: Observable;\r\n\r\n ngOnInit() {\r\n this.getCategories();\r\n }\r\n\r\n getCategories() {\r\n let aggregationsQuery = QueryBuilder.buildAggregations([]);\r\n this.loadingIndicator.start();\r\n this.resource.search(null, aggregationsQuery)\r\n .subscribe(res => {\r\n this.categories\r\n .forEach(category => this.categoryData[SEARCH_FIELD_SPEC[category].name] = this.removeEmpty(res.categories[SEARCH_FIELD_SPEC[category].name]))\r\n //this.categoryData = res.categories;\r\n this.loadingIndicator.stop();\r\n }, () => this.loadingIndicator.stop());\r\n }\r\n\r\n removeEmpty(category) {\r\n return category;\r\n //return category.filter(item => item.count);\r\n }\r\n\r\n selectCategory(category: SearchFieldType, value: any) {\r\n this.state.change$.next({\r\n q: [{\r\n ...new SearchField(category, value.key),\r\n controlMetadata: {\r\n model: value\r\n }\r\n }]\r\n });\r\n\r\n this.router.navigate(['/search']);\r\n }\r\n}\r\n","module.exports = \":host.small-padding #searchFilterRoot {\\n padding-top: 48px;\\n padding-bottom: 48px;\\n}\\n\\n#searchFilterRoot {\\n background-color: #0072b5;\\n background: #0072b5;\\n background-image: url('home_1.jpg');\\n background-size: cover;\\n background-repeat: no-repeat;\\n padding-top: 183px;\\n padding-bottom: 242px;\\n}\\n\\n#searchFilterRoot .section-title {\\n color: #ffffff;\\n}\\n\\n#searchFilterRoot .btn-secondary:hover {\\n background-color: #ff9800;\\n}\\n\\n.row {\\n padding: 0px 8px;\\n}\\n\\n.row > div {\\n padding: 8px;\\n}\\n\\n.contain-text {\\n width: 80%;\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n}\\n\\n.field-type-label {\\n color: #ffffff;\\n}\\n\\n.btn.main {\\n background-color: #ff9800;\\n color: #ffffff;\\n padding: 8px 32px 8px 32px;\\n border-radius: 8px;\\n font-weight: bold;\\n text-transform: uppercase;\\n -webkit-transform: all 0.15s ease-in;\\n transform: all 0.15s ease-in;\\n}\\n\\n.btn:not(.main) {\\n height: 43px;\\n width: 43px;\\n}\\n\\n.btn + .btn {\\n margin-left: 16px;\\n}\\n\\n.link {\\n color: #ffffff;\\n font-size: 14px;\\n font-weight: bold;\\n text-decoration: none;\\n -webkit-transition: all 0.15s ease-in;\\n transition: all 0.15s ease-in;\\n text-transform: uppercase;\\n}\\n\\n.link:hover {\\n color: #ff9800;\\n}\\n\\n.sign-btn {\\n border-radius: 8px;\\n color: #ffffff;\\n}\\n\\n.sign-btn:disabled {\\n cursor: initial;\\n}\\n\\n#advancedSearchLink-xs {\\n display: none;\\n}\\n\\n#advancedSearchLink-sm {\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-pack: end;\\n justify-content: flex-end;\\n}\\n\\n@media (max-width: 1199.98px) {\\n .simple-search-root .search-row {\\n margin: 0px 100px;\\n }\\n}\\n\\n@media (max-width: 991.98px) {\\n #searchFilterRoot {\\n padding-top: 48px;\\n padding-bottom: 107px;\\n }\\n\\n .section-title {\\n font-size: 24px;\\n }\\n\\n .simple-search-root {\\n padding: 32px 8px 26px 8px;\\n }\\n .simple-search-root .search-row {\\n margin: 0px 25px;\\n }\\n\\n .btn.main:not(.advanced) {\\n padding: 8px 8px;\\n }\\n}\\n\\n@media (max-width: 767.98px) {\\n .btn.main {\\n width: 100%;\\n }\\n}\\n\\n@media (max-width: 575.98px) {\\n .simple-search-root .search-row {\\n margin: 0px 8px;\\n }\\n\\n #advancedSearchLink-sm {\\n display: none;\\n }\\n\\n #advancedSearchLink-xs {\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-pack: center;\\n justify-content: center;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/search/components/search-filter/C:\\Projects\\openscience\\Portal.WebApplication/src\\search\\components\\search-filter\\search-filter.component.scss","src/search/components/search-filter/search-filter.component.scss","src/search/components/search-filter/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/search/components/search-filter/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAOI;EACE,iBAAA;EACA,oBAAA;ACNN;;ADWA;EACE,yBEdK;EFeL,mBEfK;EFgBL,mCAAA;EACA,sBAAA;EACA,4BAAA;EACA,kBAAA;EACA,qBAAA;ACRF;;ADUE;EACE,cEjBI;ADSR;;ADWE;EACE,yBEvBK;ADcT;;ADaA;EACE,gBAAA;ACVF;;ADYE;EACE,YAAA;ACVJ;;ADcA;EACE,UAAA;EACA,gBAAA;EACA,uBAAA;EACA,mBAAA;ACXF;;ADcA;EACE,cEzCM;AD8BR;;ADcA;EACE,yBE/CO;EFgDP,cE9CM;EF+CN,0BAAA;EACA,kBAAA;EACA,iBAAA;EACA,yBAAA;EACA,oCAAA;UAAA,4BAAA;ACXF;;ADcA;EACE,YA3DU;EA4DV,WA5DU;ACiDZ;;ADcA;EACE,iBAAA;ACXF;;ADcA;EACE,cEhEM;EFiEN,eAAA;EACA,iBAAA;EACA,qBAAA;EACA,qCAAA;EAAA,6BAAA;EACA,yBAAA;ACXF;;ADaE;EACE,cE1EK;AD+DT;;ADeA;EACE,kBAAA;EACA,cE9EM;ADkER;;ADcE;EACE,eAAA;ACZJ;;ADgBA;EACE,aAAA;ACbF;;ADgBA;EACE,oBAAA;EAAA,aAAA;EACA,qBAAA;UAAA,yBAAA;ACbF;;AEZI;EH8BA;IACE,iBAAA;ECdJ;AACF;;AElBI;EHqCF;IACE,iBAAA;IACA,qBAAA;EChBF;;EDmBA;IACE,eAAA;EChBF;;EDmBA;IACE,0BAAA;EChBF;EDkBE;IACE,gBAAA;EChBJ;;EDoBA;IACE,gBAAA;ECjBF;AACF;;AEvCI;EH6DF;IACE,WAAA;ECnBF;AACF;;AE5CI;EHoEA;IACE,eAAA;ECrBJ;;EDyBA;IACE,aAAA;ECtBF;;EDyBA;IACE,oBAAA;IAAA,aAAA;IACA,wBAAA;YAAA,uBAAA;ECtBF;AACF","file":"src/search/components/search-filter/search-filter.component.scss","sourcesContent":["@import '../../../variables';\r\n@import '../../../mixins';\r\n\r\n$btn-width: 43px;\r\n\r\n:host {\r\n  &.small-padding {\r\n    #searchFilterRoot {\r\n      padding-top: 48px;\r\n      padding-bottom: 48px;\r\n    }\r\n  }\r\n}\r\n\r\n#searchFilterRoot  {\r\n  background-color: $primary;\r\n  background: $primary;\r\n  background-image: url('../../../assets/img/home_1.jpg');\r\n  background-size: cover;\r\n  background-repeat: no-repeat;\r\n  padding-top: 183px;\r\n  padding-bottom: 242px;\r\n\r\n  .section-title {\r\n    color: $white;\r\n  }\r\n\r\n  .btn-secondary:hover {\r\n    background-color: $secondary;\r\n  }\r\n}\r\n\r\n.row {\r\n  padding: 0px 8px;\r\n\r\n  & > div {\r\n    padding: 8px;\r\n  }\r\n}\r\n\r\n.contain-text {\r\n  width: 80%;\r\n  overflow: hidden;\r\n  text-overflow: ellipsis;\r\n  white-space: nowrap;\r\n}\r\n\r\n.field-type-label {\r\n  color: $white;\r\n}\r\n\r\n.btn.main {\r\n  background-color: $secondary;\r\n  color: $white;\r\n  padding: 8px 32px 8px 32px;\r\n  border-radius: 8px;\r\n  font-weight: bold;\r\n  text-transform: uppercase;\r\n  transform: all .15s ease-in;\r\n}\r\n\r\n.btn:not(.main) {\r\n  height: $btn-width;\r\n  width: $btn-width;\r\n}\r\n\r\n.btn + .btn {\r\n  margin-left: 16px;\r\n}\r\n\r\n.link {\r\n  color: $white;\r\n  font-size: 14px;\r\n  font-weight: bold;\r\n  text-decoration: none;\r\n  transition: all .15s ease-in;\r\n  text-transform: uppercase;\r\n\r\n  &:hover {\r\n    color: $secondary;\r\n  }\r\n}\r\n\r\n.sign-btn {\r\n  border-radius: 8px;\r\n  color: $white;\r\n\r\n  &:disabled {\r\n    cursor: initial;\r\n  }\r\n}\r\n\r\n#advancedSearchLink-xs {\r\n  display: none;\r\n}\r\n\r\n#advancedSearchLink-sm {\r\n  display: flex;\r\n  justify-content: flex-end;\r\n}\r\n\r\n@include media-breakpoint-down(\"lg\") {\r\n  .simple-search-root {\r\n    .search-row {\r\n      margin: 0px 100px;\r\n    }\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"md\") {\r\n  #searchFilterRoot {\r\n    padding-top: 48px;\r\n    padding-bottom: 107px;\r\n  }\r\n\r\n  .section-title {\r\n    font-size: 24px;\r\n  }\r\n  \r\n  .simple-search-root {\r\n    padding: 32px 8px 26px 8px;\r\n\r\n    .search-row {\r\n      margin: 0px 25px;\r\n    }\r\n  }\r\n\r\n  .btn.main:not(.advanced) {\r\n    padding: 8px 8px;\r\n  }\r\n\r\n}\r\n\r\n@include media-breakpoint-down(\"sm\"){\r\n  .btn.main {\r\n    width: 100%;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"xs\") {\r\n  .simple-search-root {\r\n    .search-row {\r\n      margin: 0px 8px;\r\n    }\r\n  }\r\n\r\n  #advancedSearchLink-sm {\r\n    display: none;\r\n  }\r\n\r\n  #advancedSearchLink-xs {\r\n    display: flex;\r\n    justify-content: center;\r\n  }\r\n}\r\n",":host.small-padding #searchFilterRoot {\n  padding-top: 48px;\n  padding-bottom: 48px;\n}\n\n#searchFilterRoot {\n  background-color: #0072b5;\n  background: #0072b5;\n  background-image: url(\"../../../assets/img/home_1.jpg\");\n  background-size: cover;\n  background-repeat: no-repeat;\n  padding-top: 183px;\n  padding-bottom: 242px;\n}\n#searchFilterRoot .section-title {\n  color: #ffffff;\n}\n#searchFilterRoot .btn-secondary:hover {\n  background-color: #ff9800;\n}\n\n.row {\n  padding: 0px 8px;\n}\n.row > div {\n  padding: 8px;\n}\n\n.contain-text {\n  width: 80%;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n\n.field-type-label {\n  color: #ffffff;\n}\n\n.btn.main {\n  background-color: #ff9800;\n  color: #ffffff;\n  padding: 8px 32px 8px 32px;\n  border-radius: 8px;\n  font-weight: bold;\n  text-transform: uppercase;\n  transform: all 0.15s ease-in;\n}\n\n.btn:not(.main) {\n  height: 43px;\n  width: 43px;\n}\n\n.btn + .btn {\n  margin-left: 16px;\n}\n\n.link {\n  color: #ffffff;\n  font-size: 14px;\n  font-weight: bold;\n  text-decoration: none;\n  transition: all 0.15s ease-in;\n  text-transform: uppercase;\n}\n.link:hover {\n  color: #ff9800;\n}\n\n.sign-btn {\n  border-radius: 8px;\n  color: #ffffff;\n}\n.sign-btn:disabled {\n  cursor: initial;\n}\n\n#advancedSearchLink-xs {\n  display: none;\n}\n\n#advancedSearchLink-sm {\n  display: flex;\n  justify-content: flex-end;\n}\n\n@media (max-width: 1199.98px) {\n  .simple-search-root .search-row {\n    margin: 0px 100px;\n  }\n}\n@media (max-width: 991.98px) {\n  #searchFilterRoot {\n    padding-top: 48px;\n    padding-bottom: 107px;\n  }\n\n  .section-title {\n    font-size: 24px;\n  }\n\n  .simple-search-root {\n    padding: 32px 8px 26px 8px;\n  }\n  .simple-search-root .search-row {\n    margin: 0px 25px;\n  }\n\n  .btn.main:not(.advanced) {\n    padding: 8px 8px;\n  }\n}\n@media (max-width: 767.98px) {\n  .btn.main {\n    width: 100%;\n  }\n}\n@media (max-width: 575.98px) {\n  .simple-search-root .search-row {\n    margin: 0px 8px;\n  }\n\n  #advancedSearchLink-sm {\n    display: none;\n  }\n\n  #advancedSearchLink-xs {\n    display: flex;\n    justify-content: center;\n  }\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, Input, OnDestroy } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { faMinus, faPlus, faSearch } from '@fortawesome/free-solid-svg-icons';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { bindSearchParams, clone } from 'src/infrastructure/utils';\r\nimport { LogicalOperator, LogicalOperatorsToNumberArray } from 'src/search/models/logical-operator.enum';\r\nimport { changeType, SearchField } from 'src/search/models/search-field';\r\nimport { SearchFieldMode } from 'src/search/models/search-field-mode.enum';\r\nimport { SearchFieldControlType, SEARCH_FIELD_SPEC } from 'src/search/models/search-field-type-spec';\r\nimport { SearchFieldNumberValues, SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { SearchMode } from 'src/search/models/search-mode.enum';\r\nimport { SearchState } from 'src/search/services/search.state';\r\n\r\n@Component({\r\n selector: 'search-filter-2',\r\n templateUrl: './search-filter.component.html',\r\n styleUrls: ['./search-filter.component.scss']\r\n})\r\nexport class SearchFilterComponent implements OnDestroy {\r\n\r\n constructor(\r\n private router: Router,\r\n private state: SearchState,\r\n private translate: TranslateService\r\n ) {\r\n this.currentLang = translate.currentLang;\r\n\r\n this.translate.onLangChange\r\n .pipe(takeUntil(this.destroyed$))\r\n .subscribe(lang => this.currentLang = lang.lang);\r\n\r\n this.state.change$\r\n .pipe(takeUntil(this.destroyed$))\r\n .subscribe(queryParams => this.fillFilterModels(queryParams));\r\n }\r\n\r\n ngOnDestroy(): void {\r\n this.destroyed$.next(true);\r\n this.destroyed$.unsubscribe();\r\n }\r\n\r\n @Input('clearFilter')\r\n set clearFilter(value: any) {\r\n this.state.change$.next({});\r\n }\r\n\r\n destroyed$: Subject = new Subject();\r\n searchFields: SearchField[];\r\n searchMode: SearchMode = SearchMode.simple;\r\n\r\n filter = {\r\n quickSearch: new SearchField(),\r\n fields: [new SearchField()]\r\n };\r\n SearchFieldTypeValues = SearchFieldNumberValues;\r\n SearchFieldType = SearchFieldType;\r\n SearchFieldControlType = SearchFieldControlType;\r\n SearchFieldMode = SearchFieldMode;\r\n LogicalOperator = LogicalOperator;\r\n LogicalOperatorValues = LogicalOperatorsToNumberArray;\r\n SEARCH_FIELD_SPEC = SEARCH_FIELD_SPEC;\r\n SearchMode = SearchMode;\r\n faMinus = faMinus;\r\n faPlus = faPlus;\r\n faSearch = faSearch;\r\n currentLang: string = null;\r\n\r\n fillFilterModels(queryParams: any): void {\r\n bindSearchParams(this)(queryParams);\r\n if (this.searchMode === SearchMode.simple)\r\n this.filter = {\r\n quickSearch: this.searchFields.find(e => e.mode == SearchFieldMode.allFts) || new SearchField(),\r\n fields: [new SearchField()]\r\n };\r\n else\r\n this.filter = {\r\n quickSearch: new SearchField(),\r\n fields: this.searchFields.length ? this.searchFields : [new SearchField()]\r\n };\r\n }\r\n\r\n search(): void {\r\n if (this.searchMode === SearchMode.simple) {\r\n this.state.change$.next({\r\n q: [this.filter.quickSearch],\r\n mode: SearchMode.simple\r\n });\r\n } else {\r\n this.state.change$.next({\r\n q: this.filter.fields,\r\n mode: SearchMode.advanced\r\n });\r\n }\r\n\r\n this.router.navigate(['/search']);\r\n }\r\n\r\n changeFieldType(field: SearchField, type: SearchFieldType) {\r\n changeType(field, type);\r\n }\r\n\r\n removeField(index: number) {\r\n this.filter.fields.splice(index, 1);\r\n }\r\n\r\n addField() {\r\n this.filter.fields.push(new SearchField());\r\n }\r\n\r\n handleFieldModelChange(field: SearchField, model: any) {\r\n field.controlMetadata.model = clone(model);\r\n }\r\n\r\n handleEnter(event: KeyboardEvent, searchMode: SearchMode) {\r\n this.search();\r\n return false;\r\n }\r\n\r\n handleFormSubmit(event: any) {\r\n return false;\r\n }\r\n}\r\n","module.exports = \":host:not(:last-child) {\\n display: block;\\n border-bottom: 1px solid #e7e7e7;\\n margin-bottom: 16px;\\n padding-bottom: 16px;\\n}\\n\\n.contain-text {\\n max-width: 35rem;\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n}\\n\\n.root a:hover {\\n text-decoration: none;\\n}\\n\\n.root .title-primary {\\n font-size: 22px;\\n margin-bottom: 2px;\\n}\\n\\n.root .with-separator:not(:last-child)::after {\\n content: \\\";\\\";\\n margin-right: 4px;\\n}\\n\\n.root .with-separator2 {\\n font-style: italic;\\n font-size: 16px;\\n}\\n\\n.root .with-separator2:not(:last-child)::after {\\n content: \\\"|\\\";\\n margin-right: 4px;\\n}\\n\\n.root .highlighted-section {\\n padding: 8px;\\n background-color: whitesmoke;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9zZWFyY2gvY29tcG9uZW50cy9zZWFyY2gtcmVzdWx0L0M6XFxQcm9qZWN0c1xcb3BlbnNjaWVuY2VcXFBvcnRhbC5XZWJBcHBsaWNhdGlvbi9zcmNcXHNlYXJjaFxcY29tcG9uZW50c1xcc2VhcmNoLXJlc3VsdFxcc2VhcmNoLXJlc3VsdC5jb21wb25lbnQuc2NzcyIsInNyYy9zZWFyY2gvY29tcG9uZW50cy9zZWFyY2gtcmVzdWx0L3NlYXJjaC1yZXN1bHQuY29tcG9uZW50LnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7RUFDRSxjQUFBO0VBQ0EsZ0NBQUE7RUFDQSxtQkFBQTtFQUNBLG9CQUFBO0FDREY7O0FESUE7RUFDRSxnQkFBQTtFQUNBLGdCQUFBO0VBQ0EsdUJBQUE7RUFDQSxtQkFBQTtBQ0RGOztBREtFO0VBQ0UscUJBQUE7QUNGSjs7QURLRTtFQUNFLGVBQUE7RUFDQSxrQkFBQTtBQ0hKOztBRFFJO0VBQ0UsWUFBQTtFQUNBLGlCQUFBO0FDTk47O0FEVUU7RUFFRSxrQkFBQTtFQUNBLGVBQUE7QUNUSjs7QURVSTtFQUNFLFlBQUE7RUFDQSxpQkFBQTtBQ1JOOztBRFlFO0VBQ0UsWUFBQTtFQUNBLDRCQUFBO0FDVkoiLCJmaWxlIjoic3JjL3NlYXJjaC9jb21wb25lbnRzL3NlYXJjaC1yZXN1bHQvc2VhcmNoLXJlc3VsdC5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIkBpbXBvcnQgJy4uLy4uLy4uL3ZhcmlhYmxlcyc7XHJcblxyXG46aG9zdDpub3QoOmxhc3QtY2hpbGQpIHtcclxuICBkaXNwbGF5OiBibG9jaztcclxuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgbGlnaHRlbigkY29sb3I6ICRncmF5LCAkYW1vdW50OiAyMCUpO1xyXG4gIG1hcmdpbi1ib3R0b206IDE2cHg7XHJcbiAgcGFkZGluZy1ib3R0b206IDE2cHg7XHJcbn1cclxuXHJcbi5jb250YWluLXRleHQge1xyXG4gIG1heC13aWR0aDogMzVyZW07XHJcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcclxuICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcclxuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xyXG59XHJcblxyXG4ucm9vdCB7XHJcbiAgYTpob3ZlciB7XHJcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XHJcbiAgfVxyXG5cclxuICAudGl0bGUtcHJpbWFyeSB7XHJcbiAgICBmb250LXNpemU6IDIycHg7XHJcbiAgICBtYXJnaW4tYm90dG9tOiAycHg7XHJcbiAgfVxyXG5cclxuICAud2l0aC1zZXBhcmF0b3Ige1xyXG4gICAgLy9jb2xvcjogZGFya2VuKCRncmF5LCA0MCUpO1xyXG4gICAgJjpub3QoOmxhc3QtY2hpbGQpOjphZnRlciB7XHJcbiAgICAgIGNvbnRlbnQ6IFwiO1wiO1xyXG4gICAgICBtYXJnaW4tcmlnaHQ6IDRweDtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC53aXRoLXNlcGFyYXRvcjIge1xyXG4gICAgLy9jb2xvcjogZGFya2VuKCRncmF5LCA0MCUpO1xyXG4gICAgZm9udC1zdHlsZTogaXRhbGljO1xyXG4gICAgZm9udC1zaXplOiAxNnB4O1xyXG4gICAgJjpub3QoOmxhc3QtY2hpbGQpOjphZnRlciB7XHJcbiAgICAgIGNvbnRlbnQ6IFwifFwiO1xyXG4gICAgICBtYXJnaW4tcmlnaHQ6IDRweDtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC5oaWdobGlnaHRlZC1zZWN0aW9uIHtcclxuICAgIHBhZGRpbmc6IDhweDtcclxuICAgIGJhY2tncm91bmQtY29sb3I6IHdoaXRlc21va2U7XHJcbiAgfVxyXG59IiwiOmhvc3Q6bm90KDpsYXN0LWNoaWxkKSB7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgI2U3ZTdlNztcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgcGFkZGluZy1ib3R0b206IDE2cHg7XG59XG5cbi5jb250YWluLXRleHQge1xuICBtYXgtd2lkdGg6IDM1cmVtO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbn1cblxuLnJvb3QgYTpob3ZlciB7XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbn1cbi5yb290IC50aXRsZS1wcmltYXJ5IHtcbiAgZm9udC1zaXplOiAyMnB4O1xuICBtYXJnaW4tYm90dG9tOiAycHg7XG59XG4ucm9vdCAud2l0aC1zZXBhcmF0b3I6bm90KDpsYXN0LWNoaWxkKTo6YWZ0ZXIge1xuICBjb250ZW50OiBcIjtcIjtcbiAgbWFyZ2luLXJpZ2h0OiA0cHg7XG59XG4ucm9vdCAud2l0aC1zZXBhcmF0b3IyIHtcbiAgZm9udC1zdHlsZTogaXRhbGljO1xuICBmb250LXNpemU6IDE2cHg7XG59XG4ucm9vdCAud2l0aC1zZXBhcmF0b3IyOm5vdCg6bGFzdC1jaGlsZCk6OmFmdGVyIHtcbiAgY29udGVudDogXCJ8XCI7XG4gIG1hcmdpbi1yaWdodDogNHB4O1xufVxuLnJvb3QgLmhpZ2hsaWdodGVkLXNlY3Rpb24ge1xuICBwYWRkaW5nOiA4cHg7XG4gIGJhY2tncm91bmQtY29sb3I6IHdoaXRlc21va2U7XG59Il19 */\"","import { Component, Input } from '@angular/core';\r\nimport { SearchResultItem } from 'src/search/models/search-result-item';\r\nimport { faCopy } from '@fortawesome/free-regular-svg-icons';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\nimport { faTag } from '@fortawesome/free-solid-svg-icons';\r\n\r\n@Component({\r\n selector: 'search-result',\r\n templateUrl: './search-result.component.html',\r\n styleUrls: ['./search-result.component.scss', '../../../common.scss']\r\n})\r\nexport class SearchResultComponent {\r\n @Input('model') model: SearchResultItem;\r\n\r\n faCopy = faCopy;\r\n bookmarkIcon = faTag;\r\n\r\n constructor(\r\n private translate: TranslateService,\r\n public locale: LocaleService\r\n ) { }\r\n}\r\n","module.exports = \"@charset \\\"UTF-8\\\";\\n.category {\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-orient: vertical;\\n -webkit-box-direction: normal;\\n flex-direction: column;\\n margin-bottom: 24px;\\n}\\n.category .toggles {\\n /* Hide the input elements and use there psuedo elements */\\n /* hide the input element */\\n}\\n.category .toggles label {\\n line-height: 1.5rem;\\n position: relative;\\n display: inline-block;\\n padding-left: 1.5rem;\\n width: 100%;\\n margin-bottom: 0;\\n /* Radio's setup */\\n /* The radio button background */\\n /* Checkbox setup */\\n /* the check box background */\\n /* Label hover state */\\n /* Create an alternative stlye for switches */\\n}\\n.category .toggles label:before, .category .toggles label:after {\\n box-sizing: border-box;\\n line-height: 1.5rem;\\n content: \\\" \\\";\\n display: block;\\n position: absolute;\\n top: 0.3658536585rem;\\n left: 0;\\n width: 0.75rem;\\n height: 0.75rem;\\n border-radius: 100%;\\n}\\n.category .toggles label:before {\\n width: 1rem;\\n height: 1rem;\\n margin: -0.125rem;\\n -webkit-transition: background 0.36s;\\n transition: background 0.36s;\\n}\\n.category .toggles label:after {\\n border: 0.125rem solid #ffffff;\\n -webkit-transform: scale(0);\\n transform: scale(0);\\n -webkit-transition: background 0.12s, -webkit-transform 0.16s;\\n transition: background 0.12s, -webkit-transform 0.16s;\\n transition: background 0.12s, transform 0.16s;\\n transition: background 0.12s, transform 0.16s, -webkit-transform 0.16s;\\n}\\n.category .toggles label:before {\\n border: 0.125rem solid #0072b5;\\n}\\n.category .toggles label.checkbox:before, .category .toggles label.checkbox:after {\\n border-radius: 0;\\n}\\n.category .toggles label.checkbox:before {\\n width: 1rem;\\n height: 1rem;\\n border-radius: 0;\\n}\\n.category .toggles label:hover {\\n color: #0072b5;\\n}\\n.category .toggles label.switch {\\n padding-left: 2.25rem;\\n display: block;\\n}\\n.category .toggles label.switch:before {\\n width: 1.75rem;\\n height: 1rem;\\n border: 0.125rem solid #b4b4b4;\\n}\\n.category .toggles label.switch:After {\\n -webkit-transform: scale(1);\\n transform: scale(1);\\n background: #b4b4b4;\\n}\\n.category .toggles label.switch.round:before {\\n border-radius: 40%/80%;\\n}\\n.category .toggles label.switch.round:after {\\n border-radius: 100%;\\n}\\n.category .toggles label.switch.material:before {\\n top: 0.625rem;\\n width: 1.75rem;\\n height: 0.5rem;\\n border-radius: 20%/40%;\\n border: none;\\n background: #d8d8d8;\\n}\\n.category .toggles label.switch.material:after {\\n top: 0.25rem;\\n left: -0.125rem;\\n border: none;\\n border-radius: 100%;\\n width: 1rem;\\n height: 1rem;\\n}\\n.category .toggles input[type=radio] {\\n display: none;\\n}\\n.category .toggles input[type=radio]:checked + label:after {\\n -webkit-transform: scale(1);\\n transform: scale(1);\\n background: #0072b5;\\n}\\n.category .toggles input[type=checkbox] {\\n display: none;\\n /* style active state psuedo element */\\n}\\n.category .toggles input[type=checkbox]:checked + label:after {\\n content: \\\"✓\\\";\\n display: inline-block;\\n background: #fff;\\n color: #0072b5;\\n line-height: 0.875rem;\\n font-size: 0.75rem;\\n font-weight: bold;\\n text-align: center;\\n -webkit-transform: scale(1);\\n transform: scale(1);\\n border: none;\\n}\\n.category .toggles input[type=radio],\\n.category .toggles input[type=checkbox] {\\n /* Add additional adjustments for switch style */\\n}\\n.category .toggles input[type=radio]:checked + label.switch:before,\\n.category .toggles input[type=checkbox]:checked + label.switch:before {\\n border-color: #0072b5;\\n}\\n.category .toggles input[type=radio]:checked + label.switch.material:before,\\n.category .toggles input[type=checkbox]:checked + label.switch.material:before {\\n background: #007fc9;\\n}\\n.category .toggles input[type=radio]:checked + label.switch:after,\\n.category .toggles input[type=checkbox]:checked + label.switch:after {\\n -webkit-transform: translateX(0.75rem);\\n transform: translateX(0.75rem);\\n border: 0.125rem solid #ffffff;\\n content: \\\"\\\";\\n}\\n.category .toggles input[type=radio]:checked + label.switch.material:after,\\n.category .toggles input[type=checkbox]:checked + label.switch.material:after {\\n background: #0072b5;\\n border: none;\\n}\\n.category .contain-text {\\n display: inline-block;\\n max-width: 19em;\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n}\\n.category.special .title {\\n text-transform: uppercase;\\n color: #ff9800;\\n font-size: 18px;\\n font-weight: bold;\\n}\\n.category #filters-container {\\n margin-left: -8px;\\n border-radius: 0px;\\n border: 2px solid #c5c5c5;\\n background-color: whitesmoke;\\n padding: 4px 8px;\\n}\\n.category #filters {\\n border-radius: 0px;\\n border: 2px solid #c5c5c5;\\n background-color: whitesmoke;\\n padding: 12px 24px;\\n line-height: 24px;\\n}\\n.category .title {\\n font-size: 19px;\\n font-weight: bold;\\n color: black;\\n}\\n.category #sidebar-clear {\\n cursor: pointer;\\n color: #0072b5;\\n font-size: 16px;\\n font-weight: bold;\\n -webkit-transition: all 0.15s linear;\\n transition: all 0.15s linear;\\n}\\n.category #sidebar-clear:hover {\\n color: #ff9800;\\n}\\n.category #sidebar-clear > fa-icon {\\n margin-right: 4px;\\n}\\n.category > div {\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-orient: vertical;\\n -webkit-box-direction: normal;\\n flex-direction: column;\\n}\\n.category .toggles {\\n font-size: 16px;\\n font-weight: normal;\\n font-stretch: condensed;\\n color: black;\\n margin-left: 2px;\\n}\\n.category .toggles > span {\\n margin-top: 16px;\\n}\\n.category .toggles label:hover {\\n color: #ff9800;\\n}\\n.category .toggles input, .category .toggles label {\\n cursor: pointer !important;\\n}\\n.category .link {\\n font-weight: bold;\\n text-decoration: none;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/search/components/search-sidebar/search-sidebar.component.scss","src/search/components/search-sidebar/C:\\Projects\\openscience\\Portal.WebApplication/src\\search\\components\\search-sidebar\\search-sidebar.component.scss","src/search/components/search-sidebar/C:\\Projects\\openscience\\Portal.WebApplication/src\\mixins.scss","src/search/components/search-sidebar/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss"],"names":[],"mappings":"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","file":"src/search/components/search-sidebar/search-sidebar.component.scss","sourcesContent":["@charset \"UTF-8\";\n.category {\n  display: flex;\n  flex-direction: column;\n  margin-bottom: 24px;\n}\n.category .toggles {\n  /* Hide the input elements and use there psuedo elements */\n  /* hide the input element */\n}\n.category .toggles label {\n  line-height: 1.5rem;\n  position: relative;\n  display: inline-block;\n  padding-left: 1.5rem;\n  width: 100%;\n  margin-bottom: 0;\n  /* Radio's setup */\n  /* The radio button background */\n  /* Checkbox setup */\n  /* the check box background */\n  /* Label hover state */\n  /* Create an alternative stlye for switches */\n}\n.category .toggles label:before, .category .toggles label:after {\n  box-sizing: border-box;\n  line-height: 1.5rem;\n  content: \" \";\n  display: block;\n  position: absolute;\n  top: 0.3658536585rem;\n  left: 0;\n  width: 0.75rem;\n  height: 0.75rem;\n  border-radius: 100%;\n}\n.category .toggles label:before {\n  width: 1rem;\n  height: 1rem;\n  margin: -0.125rem;\n  transition: background 0.36s;\n}\n.category .toggles label:after {\n  border: 0.125rem solid #ffffff;\n  transform: scale(0);\n  transition: background 0.12s, transform 0.16s;\n}\n.category .toggles label:before {\n  border: 0.125rem solid #0072b5;\n}\n.category .toggles label.checkbox:before, .category .toggles label.checkbox:after {\n  border-radius: 0;\n}\n.category .toggles label.checkbox:before {\n  width: 1rem;\n  height: 1rem;\n  border-radius: 0;\n}\n.category .toggles label:hover {\n  color: #0072b5;\n}\n.category .toggles label.switch {\n  padding-left: 2.25rem;\n  display: block;\n}\n.category .toggles label.switch:before {\n  width: 1.75rem;\n  height: 1rem;\n  border: 0.125rem solid #b4b4b4;\n}\n.category .toggles label.switch:After {\n  transform: scale(1);\n  background: #b4b4b4;\n}\n.category .toggles label.switch.round:before {\n  border-radius: 40%/80%;\n}\n.category .toggles label.switch.round:after {\n  border-radius: 100%;\n}\n.category .toggles label.switch.material:before {\n  top: 0.625rem;\n  width: 1.75rem;\n  height: 0.5rem;\n  border-radius: 20%/40%;\n  border: none;\n  background: #d8d8d8;\n}\n.category .toggles label.switch.material:after {\n  top: 0.25rem;\n  left: -0.125rem;\n  border: none;\n  border-radius: 100%;\n  width: 1rem;\n  height: 1rem;\n}\n.category .toggles input[type=radio] {\n  display: none;\n}\n.category .toggles input[type=radio]:checked + label:after {\n  transform: scale(1);\n  background: #0072b5;\n}\n.category .toggles input[type=checkbox] {\n  display: none;\n  /* style active state psuedo element */\n}\n.category .toggles input[type=checkbox]:checked + label:after {\n  content: \"✓\";\n  display: inline-block;\n  background: #fff;\n  color: #0072b5;\n  line-height: 0.875rem;\n  font-size: 0.75rem;\n  font-weight: bold;\n  text-align: center;\n  transform: scale(1);\n  border: none;\n}\n.category .toggles input[type=radio],\n.category .toggles input[type=checkbox] {\n  /* Add additional adjustments for switch style */\n}\n.category .toggles input[type=radio]:checked + label.switch:before,\n.category .toggles input[type=checkbox]:checked + label.switch:before {\n  border-color: #0072b5;\n}\n.category .toggles input[type=radio]:checked + label.switch.material:before,\n.category .toggles input[type=checkbox]:checked + label.switch.material:before {\n  background: #007fc9;\n}\n.category .toggles input[type=radio]:checked + label.switch:after,\n.category .toggles input[type=checkbox]:checked + label.switch:after {\n  transform: translateX(0.75rem);\n  border: 0.125rem solid #ffffff;\n  content: \"\";\n}\n.category .toggles input[type=radio]:checked + label.switch.material:after,\n.category .toggles input[type=checkbox]:checked + label.switch.material:after {\n  background: #0072b5;\n  border: none;\n}\n.category .contain-text {\n  display: inline-block;\n  max-width: 19em;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n.category.special .title {\n  text-transform: uppercase;\n  color: #ff9800;\n  font-size: 18px;\n  font-weight: bold;\n}\n.category #filters-container {\n  margin-left: -8px;\n  border-radius: 0px;\n  border: 2px solid #c5c5c5;\n  background-color: whitesmoke;\n  padding: 4px 8px;\n}\n.category #filters {\n  border-radius: 0px;\n  border: 2px solid #c5c5c5;\n  background-color: whitesmoke;\n  padding: 12px 24px;\n  line-height: 24px;\n}\n.category .title {\n  font-size: 19px;\n  font-weight: bold;\n  color: black;\n}\n.category #sidebar-clear {\n  cursor: pointer;\n  color: #0072b5;\n  font-size: 16px;\n  font-weight: bold;\n  transition: all 0.15s linear;\n}\n.category #sidebar-clear:hover {\n  color: #ff9800;\n}\n.category #sidebar-clear > fa-icon {\n  margin-right: 4px;\n}\n.category > div {\n  display: flex;\n  flex-direction: column;\n}\n.category .toggles {\n  font-size: 16px;\n  font-weight: normal;\n  font-stretch: condensed;\n  color: black;\n  margin-left: 2px;\n}\n.category .toggles > span {\n  margin-top: 16px;\n}\n.category .toggles label:hover {\n  color: #ff9800;\n}\n.category .toggles input, .category .toggles label {\n  cursor: pointer !important;\n}\n.category .link {\n  font-weight: bold;\n  text-decoration: none;\n}","@import '../../../variables';\r\n@import '../../../mixins';\r\n\r\n.category {\r\n  @include formToggles(16px, 1.5rem, 2, $pastel-blue, $white, $gray);\r\n  display: flex;\r\n  flex-direction: column;\r\n  margin-bottom: 24px;\r\n\r\n  .contain-text {\r\n    display: inline-block;\r\n    max-width: 19em;\r\n    overflow: hidden;\r\n    text-overflow: ellipsis;\r\n    white-space: nowrap;\r\n  }\r\n\r\n  &.special .title {\r\n    text-transform: uppercase;\r\n    color: $secondary;\r\n    font-size: 18px;\r\n    font-weight: bold;\r\n  }\r\n\r\n\r\n  #filters-container {\r\n    margin-left: -8px;\r\n    border-radius: 0px;\r\n    border: 2px solid #c5c5c5;\r\n    background-color: whitesmoke;\r\n    padding: 4px 8px;\r\n  }\r\n\r\n  #filters {\r\n    border-radius: 0px;\r\n    border: 2px solid #c5c5c5;\r\n    background-color: whitesmoke;\r\n    padding: 12px 24px;\r\n    line-height: 24px;\r\n  }\r\n\r\n  .title {\r\n    font-size: 19px;\r\n    font-weight: bold;\r\n    color: $black;\r\n  }\r\n\r\n  #sidebar-clear {\r\n    cursor: pointer;\r\n    color: $primary;\r\n    font-size: 16px;\r\n    font-weight: bold;\r\n    transition: all .15s linear;\r\n\r\n    &:hover {\r\n      color: $secondary;\r\n    }\r\n\r\n    & > fa-icon {\r\n      margin-right: 4px;\r\n    }\r\n  }\r\n  \r\n  & > div {\r\n    display: flex;\r\n    flex-direction: column;\r\n  }\r\n\r\n  .toggles {\r\n    font-size: 16px;\r\n    font-weight: normal;\r\n    font-stretch: condensed;\r\n    color: $black;\r\n    margin-left: 2px;\r\n\r\n    & > span {\r\n      margin-top: 16px;\r\n    }\r\n\r\n    label:hover {\r\n      color: $secondary;\r\n    }\r\n  }\r\n\r\n  .toggles input, .toggles label {\r\n    cursor: pointer !important;\r\n  }\r\n\r\n  .link {\r\n    font-weight: bold;\r\n    text-decoration: none;\r\n  }\r\n}\r\n\r\n","@import \"node_modules/bootstrap/scss/mixins/_breakpoints.scss\";\r\n@import \"variables\";\r\n\r\n/// Mixin to customize scrollbars\r\n/// Beware, this does not work in all browsers\r\n/// @author Hugo Giraudel\r\n/// @param {Length} $size - Horizontal scrollbar's height and vertical scrollbar's width\r\n/// @param {Color} $foreground-color - Scrollbar's color\r\n/// @param {Color} $background-color [mix($foreground-color, white, 50%)] - Scrollbar's color\r\n/// @example scss - Scrollbar styling\r\n///   @include scrollbars(.5em, slategray);\r\n@mixin scrollbars(\r\n  $size, \r\n  $foreground-color, \r\n  $background-color: mix($foreground-color, white,  50%)\r\n) {\r\n  // For Google Chrome\r\n  &::-webkit-scrollbar {\r\n      width:  $size;\r\n      height: $size;\r\n  }\r\n\r\n  &::-webkit-scrollbar-thumb {\r\n      background: $foreground-color;\r\n  }\r\n\r\n  &::-webkit-scrollbar-track {\r\n      background: $background-color;\r\n  }\r\n\r\n  // For Internet Explorer\r\n  & body {\r\n    scrollbar-face-color: $foreground-color;\r\n    scrollbar-track-color: $background-color;\r\n  }\r\n}\r\n\r\n@mixin formToggles(\r\n  $fontSize:16px, \r\n  $lineHeight: 1.5rem, \r\n  $border:2, \r\n  $bg: $primary, \r\n  $fg: #FFFFFF, \r\n  $disable: #CCCCCC\r\n) {\r\n  // strip the units (expecting a px value, but remove so we've just got an int)\r\n  $baseFont: ($fontSize) / ($fontSize * 0 + 1);\r\n  // ensure our base is a rem val\r\n  $base: ($lineHeight) / ($lineHeight * 0 + 1) * 1rem;\r\n  // get our borderwidth in rems\r\n  $borderWidth: (($border) / ($border * 0 + 1) / $baseFont) * 1rem;\r\n  .toggles {\r\n    label {\r\n      line-height: $base;\r\n      position: relative;\r\n      display: inline-block;\r\n      padding-left: $base;\r\n      width: 100%;\r\n      margin-bottom: 0;\r\n      &:before,\r\n      &:after {\r\n        box-sizing: border-box;\r\n        line-height: $base;\r\n        content: ' ';\r\n        display: block;\r\n        position: absolute;\r\n        top: $base/4.1;\r\n        left: 0;\r\n        width: $base/2;\r\n        height: $base/2;\r\n        border-radius: 100%;\r\n      }\r\n      &:before {\r\n        width: ($base/2)+$borderWidth*2;\r\n        height: ($base/2)+$borderWidth*2;\r\n        margin: -$borderWidth;\r\n        transition: background .36s;\r\n      }\r\n      /* Radio's setup */\r\n      &:after {\r\n        border: $borderWidth solid $fg;\r\n        transform: scale(0);\r\n        transition: background .12s, transform .16s;\r\n      }\r\n      /* The radio button background */\r\n      &:before {\r\n        border: $borderWidth solid $bg;\r\n      }\r\n      /* Checkbox setup */\r\n      &.checkbox:before,\r\n      &.checkbox:after {\r\n        border-radius: 0;\r\n      }\r\n      /* the check box background */\r\n      &.checkbox:before {\r\n        width: ($base/2)+$borderWidth*2;\r\n        height: ($base/2)+$borderWidth*2;\r\n        border-radius: 0;\r\n      }\r\n      /* Label hover state */\r\n      &:hover {\r\n        color: $bg;\r\n      }\r\n      /* Create an alternative stlye for switches */\r\n      &.switch {\r\n        padding-left: $base * 1.5;\r\n        display: block;\r\n        &:before {\r\n          width: ($base)+$borderWidth*2;\r\n          height: ($base/2)+$borderWidth*2;\r\n          border: $borderWidth solid $disable;\r\n        }\r\n        &:After {\r\n          transform: scale(1);\r\n          background: $disable;\r\n        }\r\n        &.round:before {\r\n          border-radius: 40%/80%;\r\n        }\r\n        &.round:after {\r\n          border-radius: 100%;\r\n        }\r\n        &.material:before {\r\n          top: $base/4+$borderWidth*2;\r\n          width: ($base)+$borderWidth*2;\r\n          height: ($base/2)-$borderWidth*2;\r\n          border-radius: 20%/40%;\r\n          border: none;\r\n          background: lighten($disable, 14%);\r\n        }\r\n        &.material:after {\r\n          top: $base/4-$borderWidth;\r\n          left: -$borderWidth;\r\n          border: none;\r\n          border-radius: 100%;\r\n          width: $base/2+$borderWidth*2;\r\n          height: $base/2+$borderWidth*2;\r\n        }\r\n      }\r\n    }\r\n    /* Hide the input elements and use there psuedo elements */\r\n    input[type=\"radio\"] {\r\n      display: none;\r\n      &:checked + label:after {\r\n        transform: scale(1);\r\n        background: $bg;\r\n      }\r\n    }\r\n    /* hide the input element */\r\n    input[type=\"checkbox\"] {\r\n      display: none;\r\n      /* style active state psuedo element */\r\n      &:checked + label:after {\r\n        content: '\\2713';\r\n        display: inline-block;\r\n        background: #fff;\r\n        color:$bg;\r\n        line-height: $base/2+$borderWidth;\r\n        font-size: $base/2;\r\n        font-weight: bold;\r\n        text-align: center;\r\n        transform: scale(1);\r\n        border: none;\r\n      }\r\n    }\r\n    // switch active states\r\n    input[type=\"radio\"],\r\n    input[type=\"checkbox\"] {\r\n      /* Add additional adjustments for switch style */\r\n      &:checked + label.switch {\r\n        &:before {\r\n          border-color: $bg;\r\n        }\r\n        &.material:before {\r\n          background: lighten($primary, 4%);\r\n        }\r\n      }\r\n      &:checked + label.switch {\r\n        &:after {\r\n          // no 3d, to support ie9+\r\n          transform: translateX($base*0.5);\r\n          border: $borderWidth solid $fg;\r\n          content: '';\r\n        }\r\n        &.material:after {\r\n          background: $primary;\r\n          border: none;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;"]} */\"","import { Component, OnInit, Input } from '@angular/core';\r\nimport { SearchFieldType, SearchFieldCategories } from 'src/search/models/search-field-type.enum';\r\nimport { SearchFieldControlType, SEARCH_FIELD_SPEC } from 'src/search/models/search-field-type-spec';\r\nimport { faTimes } from '@fortawesome/free-solid-svg-icons';\r\nimport { faTimesCircle } from '@fortawesome/free-regular-svg-icons';\r\nimport { SearchField } from 'src/search/models/search-field';\r\nimport { Router } from '@angular/router';\r\nimport { SearchMode } from 'src/search/models/search-mode.enum';\r\nimport { SearchState } from 'src/search/services/search.state';\r\n\r\n@Component({\r\n selector: 'search-sidebar',\r\n templateUrl: './search-sidebar.component.html',\r\n styleUrls: ['./search-sidebar.component.scss']\r\n})\r\nexport class SearchSidebarComponent implements OnInit {\r\n\r\n constructor(\r\n private router: Router,\r\n private state: SearchState\r\n ) { }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n @Input()\r\n searchFields: SearchField[] = [];\r\n\r\n @Input()\r\n categories: any = {};\r\n\r\n SearchFieldType = SearchFieldType;\r\n SearchFieldControlType = SearchFieldControlType;\r\n SEARCH_FIELD_SPEC = SEARCH_FIELD_SPEC;\r\n SearchFieldCategories = SearchFieldCategories;\r\n faTimesCircle = faTimesCircle;\r\n faTimes = faTimes;\r\n\r\n search() {\r\n this.state.change$.next({\r\n q: this.searchFields,\r\n page: 0,\r\n mode: SearchMode.simple\r\n });\r\n }\r\n\r\n handleCheckboxChange(fieldType: SearchFieldType, item: any) {\r\n if (item.selected)\r\n this.removeFilter(fieldType, item);\r\n else\r\n this.searchFields.push(new SearchField(fieldType, item.key, item));\r\n\r\n this.search();\r\n }\r\n\r\n handleFilterRemove(index: number) {\r\n if (this.removeAt(index))\r\n this.search();\r\n }\r\n\r\n private removeFilter(fieldType: SearchFieldType, item: any) {\r\n let index = this.searchFields.findIndex((e: SearchField) => e.type == fieldType\r\n && e.searchTerm == item.key);\r\n\r\n this.removeAt(index);\r\n }\r\n\r\n // @Debug()\r\n private removeAt(index: number): boolean {\r\n if (index > -1) {\r\n this.searchFields.splice(index, 1);\r\n return true;\r\n }\r\n else\r\n return false;\r\n }\r\n\r\n clearFilter() {\r\n this.state.change$.next({});\r\n }\r\n}\r\n","module.exports = \"*[zero-margin] {\\n margin-top: 0 !important;\\n}\\n\\n.results .root:first-of-type {\\n margin-top: 0;\\n}\\n\\n.filter-paginator-row > div {\\n margin-top: 8px;\\n}\\n\\n.left-column {\\n -webkit-box-flex: 2;\\n flex: 2;\\n margin-right: 32px;\\n}\\n\\n.right-column {\\n -webkit-box-flex: 3;\\n flex: 3;\\n max-width: 100%;\\n}\\n\\n[opener] {\\n display: none !important;\\n}\\n\\n#content {\\n padding: 16px;\\n margin-bottom: 0px;\\n}\\n\\n.loading .right-column .placeholder {\\n background-color: #f9f5f5;\\n margin-bottom: 32px;\\n padding: 4px 16px;\\n border-radius: 8px;\\n}\\n\\n.loading .right-column .placeholder div {\\n border-radius: 8px;\\n background-color: #e2e2e2;\\n margin: 16px 0px;\\n height: 50px;\\n}\\n\\n.loading .left-column .placeholder {\\n margin-left: -8px;\\n margin-bottom: 16px;\\n background-color: #f9f5f5;\\n padding: 4px 16px;\\n border-radius: 8px;\\n}\\n\\n.loading .left-column .placeholder div {\\n border-radius: 8px;\\n background-color: #e2e2e2;\\n margin: 16px 0px;\\n height: 30px;\\n}\\n\\n#no-items {\\n display: -webkit-box;\\n display: flex;\\n -webkit-box-orient: vertical;\\n -webkit-box-direction: normal;\\n flex-direction: column;\\n -webkit-box-pack: center;\\n justify-content: center;\\n -webkit-box-align: center;\\n align-items: center;\\n color: #0072b5;\\n}\\n\\n#no-items fa-icon {\\n font-size: 75px;\\n}\\n\\n#no-items span {\\n font-size: 30px;\\n}\\n\\n@media (max-width: 991.98px) {\\n [opener] {\\n display: -webkit-box !important;\\n display: flex !important;\\n }\\n\\n .left-column {\\n display: none;\\n }\\n}\\n\\n@media (min-width: 1200px) {\\n .left-column {\\n -webkit-box-flex: 1;\\n flex: 1;\\n }\\n\\n .right-column {\\n -webkit-box-flex: 2;\\n flex: 2;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/search/components/search/C:\\Projects\\openscience\\Portal.WebApplication/src\\search\\components\\search\\search.component.scss","src/search/components/search/search.component.scss","src/search/components/search/C:\\Projects\\openscience\\Portal.WebApplication/src\\variables.scss","src/search/components/search/C:\\Projects\\openscience\\Portal.WebApplication/node_modules\\bootstrap\\scss\\mixins\\_breakpoints.scss"],"names":[],"mappings":"AAEA;EACE,wBAAA;ACDF;;ADKE;EACE,aAAA;ACFJ;;ADOE;EACE,eAAA;ACJJ;;ADQA;EACE,mBAAA;UAAA,OAAA;EACA,kBAAA;ACLF;;ADQA;EACE,mBAAA;UAAA,OAAA;EACA,eAAA;ACLF;;ADQA;EACE,wBAAA;ACLF;;ADQA;EACE,aAAA;EACA,kBAAA;ACLF;;ADUI;EACE,yBAAA;EACA,mBAAA;EACA,iBAAA;EACA,kBAAA;ACPN;;ADSM;EACE,kBAAA;EACA,yBAAA;EACA,gBAAA;EACA,YAAA;ACPR;;ADaI;EACE,iBAAA;EACA,mBAAA;EACA,yBAAA;EACA,iBAAA;EACA,kBAAA;ACXN;;ADaM;EACE,kBAAA;EACA,yBAAA;EACA,gBAAA;EACA,YAAA;ACXR;;ADiBA;EACE,oBAAA;EAAA,aAAA;EACA,4BAAA;EAAA,6BAAA;UAAA,sBAAA;EACA,wBAAA;UAAA,uBAAA;EACA,yBAAA;UAAA,mBAAA;EACA,cE5EK;AD8DP;;ADgBE;EACE,eAAA;ACdJ;;ADiBE;EACE,eAAA;ACfJ;;AEII;EHgBF;IACE,+BAAA;IAAA,wBAAA;EChBF;;EDmBA;IACE,aAAA;EChBF;AACF;;AEnBI;EHuCF;IACE,mBAAA;YAAA,OAAA;ECjBF;;EDoBA;IACE,mBAAA;YAAA,OAAA;ECjBF;AACF","file":"src/search/components/search/search.component.scss","sourcesContent":["@import '../../../mixins';\r\n\r\n*[zero-margin] {\r\n  margin-top: 0 !important;\r\n}\r\n\r\n.results {\r\n  & .root:first-of-type {\r\n    margin-top: 0;\r\n  }\r\n}\r\n\r\n.filter-paginator-row {\r\n  & > div {\r\n    margin-top: 8px;\r\n  }\r\n}\r\n\r\n.left-column {\r\n  flex: 2;\r\n  margin-right: 32px;\r\n}\r\n\r\n.right-column {\r\n  flex: 3;\r\n  max-width: 100%;\r\n}\r\n\r\n[opener] {\r\n  display: none !important;\r\n}\r\n\r\n#content {\r\n  padding: 16px;\r\n  margin-bottom: 0px;\r\n}\r\n\r\n.loading {\r\n  .right-column {\r\n    .placeholder {\r\n      background-color: #f9f5f5;\r\n      margin-bottom: 32px;\r\n      padding: 4px 16px;\r\n      border-radius: 8px;\r\n\r\n      div {\r\n        border-radius: 8px;\r\n        background-color: #e2e2e2;\r\n        margin: 16px 0px;\r\n        height: 50px;\r\n      }\r\n    }\r\n  }\r\n\r\n  .left-column {\r\n    .placeholder {\r\n      margin-left: -8px;\r\n      margin-bottom: 16px;\r\n      background-color: #f9f5f5;\r\n      padding: 4px 16px;\r\n      border-radius: 8px;\r\n\r\n      div {\r\n        border-radius: 8px;\r\n        background-color: #e2e2e2;\r\n        margin: 16px 0px;\r\n        height: 30px;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n#no-items {\r\n  display: flex;\r\n  flex-direction: column;\r\n  justify-content: center;\r\n  align-items: center;\r\n  color: $primary;\r\n\r\n  fa-icon{\r\n    font-size: 75px;\r\n  }\r\n\r\n  span {\r\n    font-size: 30px;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-down(\"md\") {\r\n  [opener] {\r\n    display: flex !important;\r\n  }\r\n\r\n  .left-column {\r\n    display: none;\r\n  }\r\n}\r\n\r\n@include media-breakpoint-up(\"xl\") {\r\n  .left-column {\r\n    flex: 1;\r\n  }\r\n\r\n  .right-column {\r\n    flex: 2;\r\n  }\r\n}\r\n\r\n\r\n\r\n","*[zero-margin] {\n  margin-top: 0 !important;\n}\n\n.results .root:first-of-type {\n  margin-top: 0;\n}\n\n.filter-paginator-row > div {\n  margin-top: 8px;\n}\n\n.left-column {\n  flex: 2;\n  margin-right: 32px;\n}\n\n.right-column {\n  flex: 3;\n  max-width: 100%;\n}\n\n[opener] {\n  display: none !important;\n}\n\n#content {\n  padding: 16px;\n  margin-bottom: 0px;\n}\n\n.loading .right-column .placeholder {\n  background-color: #f9f5f5;\n  margin-bottom: 32px;\n  padding: 4px 16px;\n  border-radius: 8px;\n}\n.loading .right-column .placeholder div {\n  border-radius: 8px;\n  background-color: #e2e2e2;\n  margin: 16px 0px;\n  height: 50px;\n}\n.loading .left-column .placeholder {\n  margin-left: -8px;\n  margin-bottom: 16px;\n  background-color: #f9f5f5;\n  padding: 4px 16px;\n  border-radius: 8px;\n}\n.loading .left-column .placeholder div {\n  border-radius: 8px;\n  background-color: #e2e2e2;\n  margin: 16px 0px;\n  height: 30px;\n}\n\n#no-items {\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  color: #0072b5;\n}\n#no-items fa-icon {\n  font-size: 75px;\n}\n#no-items span {\n  font-size: 30px;\n}\n\n@media (max-width: 991.98px) {\n  [opener] {\n    display: flex !important;\n  }\n\n  .left-column {\n    display: none;\n  }\n}\n@media (min-width: 1200px) {\n  .left-column {\n    flex: 1;\n  }\n\n  .right-column {\n    flex: 2;\n  }\n}","// $blue: #190e8f;\r\n$blue: #0072b5;\r\n// $blue: #A8B10E;\r\n// $pastel-blue: #A8B10E;\r\n$pastel-blue: #0072b5;\r\n$orange: #ff9800;\r\n$pastel-orange: #FFB84D;\r\n$white: #ffffff;\r\n$gray: #b4b4b4;\r\n$normal: #696969;\r\n$black: darken($normal, 75%);\r\n\r\n$primary: $blue;\r\n$secondary: $orange;\r\n\r\n$theme-colors : (\r\n  \"secondary\":  $secondary,\r\n  \"normal\": $normal,\r\n  \"pastel-blue\": $pastel-blue,\r\n  \"pastel-orange\": $pastel-orange\r\n);\r\n\r\n$grid-breakpoints: (\r\n  xs: 0,\r\n  sm: 576px,\r\n  md: 768px,\r\n  lg: 992px,\r\n  xl: 1200px\r\n);\r\n\r\n$container-max-widths: (\r\n  sm: 768px,\r\n  md: 959px,\r\n  lg: 960px,\r\n  xl: 1200px\r\n);\r\n\r\n$input-border-size: 1px;\r\n$border-size: 2px;","// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n//    (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$grid-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n//    >> breakpoint-next(sm)\n//    md\n//    >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    md\n//    >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n//    md\n@function breakpoint-next($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n  $n: index($breakpoint-names, $name);\n  @return if($n != null and $n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n//    >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    576px\n@function breakpoint-min($name, $breakpoints: $grid-breakpoints) {\n  $min: map-get($breakpoints, $name);\n  @return if($min != 0, $min, null);\n}\n\n// Maximum breakpoint width. Null for the largest (last) breakpoint.\n// The maximum value is calculated as the minimum of the next one less 0.02px\n// to work around the limitations of `min-` and `max-` prefixes and viewports with fractional widths.\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n//    >> breakpoint-max(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    767.98px\n@function breakpoint-max($name, $breakpoints: $grid-breakpoints) {\n  $next: breakpoint-next($name, $breakpoints);\n  @return if($next, breakpoint-min($next, $breakpoints) - .02, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash in front.\n// Useful for making responsive utilities.\n//\n//    >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"\"  (Returns a blank string)\n//    >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n//    \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $grid-breakpoints) {\n  @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  @if $min {\n    @media (min-width: $min) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $grid-breakpoints) {\n  $max: breakpoint-max($name, $breakpoints);\n  @if $max {\n    @media (max-width: $max) {\n      @content;\n    }\n  } @else {\n    @content;\n  }\n}\n\n// Media that spans multiple breakpoint widths.\n// Makes the @content apply between the min and max breakpoints\n@mixin media-breakpoint-between($lower, $upper, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($lower, $breakpoints);\n  $max: breakpoint-max($upper, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($lower, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($upper, $breakpoints) {\n      @content;\n    }\n  }\n}\n\n// Media between the breakpoint's minimum and maximum widths.\n// No minimum for the smallest breakpoint, and no maximum for the largest one.\n// Makes the @content apply only to the given breakpoint, not viewports any wider or narrower.\n@mixin media-breakpoint-only($name, $breakpoints: $grid-breakpoints) {\n  $min: breakpoint-min($name, $breakpoints);\n  $max: breakpoint-max($name, $breakpoints);\n\n  @if $min != null and $max != null {\n    @media (min-width: $min) and (max-width: $max) {\n      @content;\n    }\n  } @else if $max == null {\n    @include media-breakpoint-up($name, $breakpoints) {\n      @content;\n    }\n  } @else if $min == null {\n    @include media-breakpoint-down($name, $breakpoints) {\n      @content;\n    }\n  }\n}\n"]} */\"","import { Component, OnDestroy, OnInit } from '@angular/core';\r\nimport { faSearch, faTimesCircle } from '@fortawesome/free-solid-svg-icons';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { PaginatorChangeEvent } from 'src/components/paginator/paginator.component';\r\nimport { LoadingIndicatorService } from 'src/infrastructure/loading-indicator.service';\r\nimport { bindSearchParams, scrollToTop } from 'src/infrastructure/utils';\r\nimport { SearchField } from 'src/search/models/search-field';\r\nimport { SearchFieldType } from 'src/search/models/search-field-type.enum';\r\nimport { SearchMode } from 'src/search/models/search-mode.enum';\r\nimport { SearchResultItem } from 'src/search/models/search-result-item';\r\nimport * as QueryBuilder from 'src/search/services/logical-operator-query-builder.service';\r\nimport { SearchResource } from 'src/search/services/search.resource';\r\nimport { SearchState } from 'src/search/services/search.state';\r\n\r\n@Component({\r\n templateUrl: 'search.component.html',\r\n styleUrls: ['search.component.scss']\r\n})\r\nexport class SearchComponent implements OnInit, OnDestroy {\r\n constructor(\r\n private resource: SearchResource,\r\n private loadingIndicator: LoadingIndicatorService,\r\n private state: SearchState,\r\n ) {\r\n this.loading = loadingIndicator.change$;\r\n }\r\n\r\n searchIcon = faSearch;\r\n faTimesCircle = faTimesCircle;\r\n searchMode: SearchMode = SearchMode.simple;\r\n searchFields: SearchField[];\r\n items: SearchResultItem[];\r\n categories: any = null;\r\n totalCount: number = -1;\r\n page: number = 0;\r\n pageSizes = [10, 25, 50, 100];\r\n pageSize = this.pageSizes[0];\r\n SearchMode = SearchMode;\r\n loading: any;\r\n\r\n destroyed$: Subject = new Subject();\r\n\r\n ngOnInit() {\r\n this.state.change$\r\n .pipe(takeUntil(this.destroyed$))\r\n .subscribe(queryParams => {\r\n bindSearchParams(this)(queryParams);\r\n this.search();\r\n });\r\n scrollToTop();\r\n }\r\n\r\n ngOnDestroy(): void {\r\n this.destroyed$.next(true);\r\n this.destroyed$.unsubscribe();\r\n }\r\n\r\n search(): void {\r\n let aggregationsQuery, searchQuery;\r\n if (this.searchMode === SearchMode.simple) {\r\n aggregationsQuery = QueryBuilder.buildCategoryAggregations(this.searchFields);\r\n searchQuery = QueryBuilder.buildCategoryFilters(this.searchFields);\r\n } else {\r\n aggregationsQuery = QueryBuilder.buildAggregations(this.searchFields);\r\n searchQuery = QueryBuilder.buildFilters(this.searchFields);\r\n }\r\n\r\n searchQuery['from'] = this.pageSize * this.page;\r\n searchQuery['size'] = this.pageSize;\r\n\r\n this.loadingIndicator.start();\r\n this.resource.search(searchQuery, aggregationsQuery)\r\n .subscribe(res => {\r\n this.totalCount = res.totalCount;\r\n this.items = res.items;\r\n this.categories = this.formatCategories(res.categories);\r\n this.loadingIndicator.stop();\r\n }, _ => this.loadingIndicator.stop());\r\n }\r\n\r\n handlePageEvent(event: PaginatorChangeEvent): void {\r\n this.state.change$.next({\r\n q: this.searchFields,\r\n page: event.page,\r\n mode: this.searchMode\r\n });\r\n\r\n scrollToTop();\r\n }\r\n\r\n formatCategories(categories: any): void {\r\n if (!categories) {\r\n return null;\r\n }\r\n\r\n const fields = this.searchFields;\r\n Object.keys(categories).forEach((category: string) => {\r\n categories[category] = categories[category].filter(item => item.count > 0);\r\n\r\n categories[category]\r\n .forEach(item => {\r\n item.selected = fields.some((e: SearchField) => e.type === SearchFieldType[category]\r\n && e.searchTerm === item.key);\r\n });\r\n });\r\n return categories;\r\n }\r\n\r\n clearFilter() {\r\n this.state.change$.next({});\r\n }\r\n}\r\n","export enum LogicalOperator {\r\n AND = 1,\r\n OR = 2\r\n}\r\n\r\nexport const LogicalOperatorsToNumberArray: LogicalOperator[] = Object.keys(LogicalOperator)\r\n .map(key => parseInt(key, 10))\r\n .filter(key => key >= 0);\r\n\r\nexport const LogicalOperatorsToValuesArray: string[] = LogicalOperatorsToNumberArray\r\n .map(key => LogicalOperator[key]);","export enum SearchFieldMode {\r\n\texact = 1,\r\n\tfts = 2,\r\n\tallFts = 3,\r\n\tmatchPhrase = 4\r\n}\r\n","import { ControlMetadata } from './control-metadata.model';\r\nimport { SearchFieldMode } from './search-field-mode.enum';\r\nimport { SearchFieldType } from './search-field-type.enum';\r\n\r\nexport enum SearchFieldControlType {\r\n text = 1,\r\n nomenclature = 2,\r\n numeric = 3,\r\n dateRange = 4\r\n}\r\n\r\nexport class SearchFieldTypeSpec {\r\n name: string;\r\n defaultMode: SearchFieldMode;\r\n defaultValue: any;\r\n controlType: SearchFieldControlType;\r\n controlMetadata: ControlMetadata;\r\n}\r\n\r\nexport const SEARCH_FIELD_SPEC = {\r\n [SearchFieldType.all]: {\r\n name: 'all',\r\n defaultMode: SearchFieldMode.allFts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.title]: {\r\n name: 'titles',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.creator]: {\r\n name: 'creators',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.creatorIdentifier]: {\r\n name: 'creatorIdentifiers',\r\n defaultMode: SearchFieldMode.matchPhrase,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.description]: {\r\n name: 'descriptions',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.subject]: {\r\n name: 'subjects',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.publisher]: {\r\n name: 'publishers',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.awardTitle]: {\r\n name: 'awardTitles',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.awardNumber]: {\r\n name: 'awardNumbers',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.resourceIdentifier]: {\r\n name: 'resourceIdentifier',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.content]: {\r\n name: 'contents',\r\n defaultMode: SearchFieldMode.fts,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.publicationYear]: {\r\n name: 'publicationYear',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.numeric,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.accessRight]: {\r\n name: 'accessRight',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: null,\r\n controlType: SearchFieldControlType.nomenclature,\r\n controlMetadata: {\r\n restUrl: \"AccessRight\",\r\n model: null\r\n }\r\n },\r\n [SearchFieldType.funderName]: {\r\n name: 'funderNames.keyword',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.fundingStream]: {\r\n name: 'fundingStreams',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.text,\r\n controlMetadata: {}\r\n },\r\n [SearchFieldType.languages]: {\r\n name: 'languages',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: null,\r\n controlType: SearchFieldControlType.nomenclature,\r\n controlMetadata: {\r\n restUrl: \"Language\",\r\n model: null\r\n }\r\n },\r\n [SearchFieldType.institution]: {\r\n name: 'institution',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: null,\r\n controlType: SearchFieldControlType.nomenclature,\r\n controlMetadata: {\r\n restUrl: \"Institution\",\r\n model: null\r\n }\r\n },\r\n [SearchFieldType.resourceType]: {\r\n name: 'resourceType',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: '',\r\n controlType: SearchFieldControlType.nomenclature,\r\n controlMetadata: {\r\n restUrl: \"ResourceType\",\r\n model: null\r\n }\r\n },\r\n [SearchFieldType.classifications]: {\r\n name: 'classifications',\r\n defaultMode: SearchFieldMode.exact,\r\n defaultValue: null,\r\n controlType: SearchFieldControlType.nomenclature,\r\n controlMetadata: {\r\n restUrl: \"Classification\",\r\n model: null\r\n }\r\n }\r\n};\r\n","export enum SearchFieldType {\r\n all = 1,\r\n title = 2,\r\n publicationYear = 19,\r\n creator = 3,\r\n creatorIdentifier = 4,\r\n description = 5,\r\n subject = 6,\r\n publisher = 7,\r\n accessRight = 9,\r\n //Funding Reference\r\n funderName = 10,\r\n awardTitle = 11,\r\n awardNumber = 12,\r\n fundingStream = 13,\r\n //-----------------\r\n languages = 14,\r\n institution = 15,\r\n resourceType = 16,\r\n resourceIdentifier = 17,\r\n content = 18,\r\n\r\n //new fields\r\n classifications = 20\r\n}\r\n\r\nexport const SearchFieldNumberValues: SearchFieldType[] = Object.keys(SearchFieldType)\r\n .map(key => parseInt(key, 10))\r\n .filter(key => key >= 0);\r\n\r\nexport const SearchFieldTypeValuesArray: string[] = SearchFieldNumberValues\r\n .map(key => SearchFieldType[key]);\r\n\r\nexport const SearchFieldCategories: SearchFieldType[] = [\r\n SearchFieldType.institution,\r\n SearchFieldType.publicationYear,\r\n SearchFieldType.resourceType,\r\n SearchFieldType.classifications,\r\n // SearchFieldType.funderName,\r\n SearchFieldType.accessRight,\r\n SearchFieldType.languages\r\n];\r\n","import { ControlMetadata } from './control-metadata.model';\r\nimport { SearchFieldMode } from './search-field-mode.enum';\r\nimport { SearchFieldType } from './search-field-type.enum';\r\nimport { SEARCH_FIELD_SPEC, SearchFieldControlType } from './search-field-type-spec';\r\nimport { clone } from '../../infrastructure/utils';\r\nimport { LogicalOperator } from './logical-operator.enum';\r\n\r\nexport class SearchField {\r\n searchTerm: string;\r\n name: string;\r\n mode: SearchFieldMode;\r\n type: SearchFieldType;\r\n logicalOperator: LogicalOperator;\r\n controlType: SearchFieldControlType;\r\n controlMetadata: ControlMetadata;\r\n\r\n constructor(type?: SearchFieldType, value?: any, model?: any, logicalOperator?: LogicalOperator) {\r\n this.type = (type || SearchFieldType.all);\r\n this.name = SEARCH_FIELD_SPEC[this.type].name;\r\n this.mode = SEARCH_FIELD_SPEC[this.type].defaultMode;\r\n this.searchTerm = SEARCH_FIELD_SPEC[this.type].defaultValue;\r\n this.logicalOperator = LogicalOperator.AND;\r\n this.controlType = SEARCH_FIELD_SPEC[this.type].controlType;\r\n this.controlMetadata = clone(SEARCH_FIELD_SPEC[this.type].controlMetadata);\r\n\r\n if (value != undefined)\r\n this.searchTerm = value;\r\n\r\n if (model !== undefined)\r\n this.controlMetadata.model = model;\r\n }\r\n}\r\n\r\nexport function changeType(field: SearchField, type: SearchFieldType) {\r\n if (type) {\r\n let spec = SEARCH_FIELD_SPEC[type];\r\n field.type = type;\r\n field.name = spec.name;\r\n field.mode = spec.defaultMode;\r\n field.controlType = spec.controlType;\r\n field.controlMetadata = clone(spec.controlMetadata);\r\n field.searchTerm = spec.defaultValue;\r\n }\r\n}","export enum SearchMode {\r\n simple,\r\n advanced\r\n};","import { NgModule } from '@angular/core';\r\nimport { RouterModule, Routes } from '@angular/router';\r\nimport { SearchComponent } from './components/search/search.component';\r\nimport { LandingPageComponent } from './components/landing-page/landing-page.component';\r\nimport { NewsComponent } from './components/news/news.component';\r\nimport { EventsComponent } from './components/events/events.component';\r\n\r\nconst routes: Routes = [\r\n {\r\n path: '',\r\n component: LandingPageComponent,\r\n pathMatch: 'full',\r\n data: {\r\n title: 'pages.home'\r\n }\r\n },\r\n {\r\n path: 'search',\r\n component: SearchComponent,\r\n data: {\r\n title: 'pages.search'\r\n }\r\n },\r\n {\r\n path: 'news',\r\n component: NewsComponent\r\n },\r\n {\r\n path: 'events',\r\n component: EventsComponent\r\n }\r\n];\r\n\r\n@NgModule({\r\n imports: [RouterModule.forChild(routes)],\r\n exports: [RouterModule],\r\n})\r\n\r\nexport class SearchRoutingModule { }\r\n","import { CommonModule } from '@angular/common';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { NgModule } from '@angular/core';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { NgBootstrapModule } from 'src/infrastructure/ng-bootstrap.module';\r\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\r\nimport { ComponentsModule } from 'src/components/components.module';\r\n\r\nimport { SearchComponent } from './components/search/search.component';\r\nimport { SearchResultComponent } from './components/search-result/search-result.component';\r\nimport { SearchRoutingModule } from './search-routing.module';\r\nimport { SearchResource } from './services/search.resource';\r\nimport { LandingPageComponent } from './components/landing-page/landing-page.component';\r\nimport { SearchCategoriesComponent } from './components/search-categories/search-categories.component';\r\nimport { SearchFilterComponent } from './components/search-filter/search-filter.component';\r\nimport { SearchSidebarComponent } from './components/search-sidebar/search-sidebar.component';\r\nimport { InformationComponent } from './components/information/information.component';\r\nimport { SharedModule } from 'src/shared/shared.module';\r\nimport { NewsComponent } from './components/news/news.component';\r\nimport { EventsComponent } from './components/events/events.component';\r\nimport { InformationItemComponent } from './components/information/information-item/information-item.component';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n FormsModule,\r\n ReactiveFormsModule,\r\n SearchRoutingModule,\r\n TranslateModule,\r\n NgBootstrapModule,\r\n ComponentsModule,\r\n SharedModule,\r\n FontAwesomeModule\r\n ],\r\n declarations: [\r\n SearchComponent,\r\n SearchResultComponent,\r\n SearchFilterComponent,\r\n LandingPageComponent,\r\n SearchCategoriesComponent,\r\n SearchSidebarComponent,\r\n InformationComponent,\r\n NewsComponent,\r\n EventsComponent,\r\n InformationItemComponent\r\n ],\r\n providers: [\r\n SearchResource\r\n ]\r\n})\r\nexport class SearchModule { }\r\n","import { LogicalOperator } from '../models/logical-operator.enum';\r\nimport { SearchField } from '../models/search-field';\r\nimport { SearchFieldMode } from '../models/search-field-mode.enum';\r\nimport { SearchFieldControlType, SEARCH_FIELD_SPEC } from '../models/search-field-type-spec';\r\nimport { SearchFieldCategories, SearchFieldType, SearchFieldTypeValuesArray } from '../models/search-field-type.enum';\r\n\r\nconst buildFieldQuery = (field: SearchField) => {\r\n if (field.mode === SearchFieldMode.exact) {\r\n return {\r\n term: {\r\n [SEARCH_FIELD_SPEC[field.type].name]: field.searchTerm\r\n }\r\n };\r\n } else if (field.mode === SearchFieldMode.matchPhrase) {\r\n return {\r\n match_phrase: {\r\n [SEARCH_FIELD_SPEC[field.type].name]: field.searchTerm\r\n }\r\n };\r\n } else if (field.mode === SearchFieldMode.fts) {\r\n return {\r\n match: {\r\n [SEARCH_FIELD_SPEC[field.type].name]: field.searchTerm\r\n }\r\n };\r\n } else if (field.mode === SearchFieldMode.allFts) {\r\n const ftsFields = SearchFieldTypeValuesArray\r\n .filter(field => SEARCH_FIELD_SPEC[SearchFieldType[field]].defaultMode === SearchFieldMode.fts);\r\n return {\r\n multi_match: {\r\n fields: ftsFields.map(field => SEARCH_FIELD_SPEC[SearchFieldType[field]].name),\r\n query: field.searchTerm,\r\n boost: 1 / ftsFields.length\r\n }\r\n };\r\n } else {\r\n return null;\r\n }\r\n};\r\n\r\nexport const buildAggregations = (fields: SearchField[]): object => {\r\n let result = {\r\n aggs: {},\r\n size: 0\r\n };\r\n\r\n SearchFieldCategories.forEach(category => {\r\n let AND_FILTERS = {\r\n bool: {\r\n must: fields\r\n .filter(field => field.type != category\r\n && field.logicalOperator == LogicalOperator.AND)\r\n .map(buildFieldQuery)\r\n .filter(e => e)\r\n }\r\n };\r\n\r\n let OR_FILTERS = fields\r\n .filter(field => field.type\r\n && field.logicalOperator == LogicalOperator.OR)\r\n .map(buildFieldQuery)\r\n .filter(e => e);\r\n\r\n let spec = SEARCH_FIELD_SPEC[category];\r\n\r\n result.aggs[spec.name] = {\r\n filter: {\r\n bool: {\r\n should: (OR_FILTERS).concat([AND_FILTERS])\r\n }\r\n },\r\n aggs: {\r\n filteredAggregation: {\r\n terms: {\r\n field: spec.name,\r\n size: 1000000\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n return result;\r\n}\r\n\r\nconst _buildCategoryFilters = (fields: SearchField[]) => {\r\n return SearchFieldTypeValuesArray.map(category => {\r\n return {\r\n bool: {\r\n should: fields\r\n .filter(field => field.type === SearchFieldType[category])\r\n .map(buildFieldQuery)\r\n .filter(e => e)\r\n }\r\n };\r\n }).filter(e => e.bool.should.length > 0);\r\n};\r\n\r\nexport const buildCategoryFilters = (fields: SearchField[]) => {\r\n return {\r\n query: {\r\n bool: {\r\n must: _buildCategoryFilters(fields)\r\n }\r\n }\r\n };\r\n};\r\n\r\nexport const buildCategoryAggregations = (fields: SearchField[]) => {\r\n let result = {\r\n aggs: {},\r\n size: 0\r\n };\r\n\r\n SearchFieldCategories.forEach(category => {\r\n let fieldsInOtherCategories = fields.filter(e => e.type !== category);\r\n let spec = SEARCH_FIELD_SPEC[category];\r\n\r\n result.aggs[spec.name] = {\r\n filter: {\r\n bool: {\r\n must: _buildCategoryFilters(fieldsInOtherCategories)\r\n }\r\n },\r\n aggs: {\r\n filteredAggregation: {\r\n terms: {\r\n field: spec.name,\r\n size: 1000000\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n return result;\r\n};\r\n\r\nexport const buildFilters = (fields: SearchField[]): object => {\r\n const AND_FILTERS = {\r\n bool: {\r\n must: fields\r\n .filter(field => field.logicalOperator === LogicalOperator.AND)\r\n .map(buildFieldQuery)\r\n .filter(e => e)\r\n }\r\n };\r\n const OR_FILTERS = fields\r\n .filter(field => field.logicalOperator === LogicalOperator.OR)\r\n .map(buildFieldQuery)\r\n .filter(e => e);\r\n\r\n return {\r\n query: {\r\n bool: {\r\n should: (OR_FILTERS).concat([AND_FILTERS])\r\n }\r\n }\r\n };\r\n};\r\n\r\n\r\nexport const parseSearchField = (field: SearchField): SearchField[] => {\r\n if (SEARCH_FIELD_SPEC[field.type].controlType !== SearchFieldControlType.text) {\r\n return [field];\r\n }\r\n\r\n const TokenType = {\r\n FREETEXT: 1,\r\n AND: 2,\r\n NOT: 3\r\n };\r\n\r\n const tokens = (field.searchTerm\r\n .match(/(\\+\\W?[а-яА-Яa-zA-Z0-9]+)|(\\-\\W?[а-яА-Яa-zA-Z0-9]+)|([а-яА-Яa-zA-Z0-9]+)/g) || [])\r\n .map(e => {\r\n let tokenType = TokenType.FREETEXT;\r\n if (e.match(/^\\+/)) {\r\n tokenType = TokenType.AND;\r\n }\r\n\r\n if (e.match(/^\\-/)) {\r\n tokenType = TokenType.NOT;\r\n }\r\n\r\n return {\r\n type: tokenType,\r\n value: e.replace(\"+\", \"\").replace(\"-\", \"\").trim()\r\n };\r\n });\r\n\r\n const metadata = {\r\n FREE_TEXT_TOKENS: [tokens.filter(e => e.type === TokenType.FREETEXT).map(e => e.value).join(\" \")],\r\n AND_TOKENS: tokens.filter(e => e.type === TokenType.AND).map(e => e.value),\r\n NOT_TOKENS: tokens.filter(e => e.type === TokenType.NOT).map(e => e.value)\r\n };\r\n\r\n // Ignoring `NOT` tokens for now\r\n const result = metadata.FREE_TEXT_TOKENS\r\n .map(token => new SearchField(field.type, token, null, LogicalOperator.AND))\r\n .concat(metadata.AND_TOKENS.map(token => new SearchField(field.type, token, null, LogicalOperator.AND)));\r\n\r\n return result;\r\n};\r\n\r\nexport class LogicalOperatorQueryBuilder {\r\n buildAggregations = buildAggregations;\r\n buildFilters = buildFilters;\r\n buildCategoryAggregations = buildCategoryAggregations;\r\n buildCategoryFilters = buildCategoryFilters;\r\n parseSearchField = parseSearchField;\r\n}\r\n","import { HttpClient } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { BaseResource } from 'src/infrastructure/base.resource';\r\nimport { Configuration } from 'src/infrastructure/configuration/configuration';\r\nimport { SearchResult } from '../models/search-result';\r\nimport { Observable } from 'rxjs';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { urlRegex } from 'src/infrastructure/utils';\r\n\r\n@Injectable()\r\nexport class SearchResource extends BaseResource {\r\n constructor(\r\n protected http: HttpClient,\r\n protected configuration: Configuration,\r\n private sanitizer: DomSanitizer\r\n ) {\r\n super(http, configuration, '');\r\n }\r\n\r\n search(search: any, aggregate?: any): Observable {\r\n return this.http.post(`${this.baseUrl}/search`, { search, aggregate })\r\n }\r\n\r\n get categories() {\r\n return this.http.get(`${this.baseUrl}/categories`);\r\n }\r\n\r\n sanitizeUrl(url: string) {\r\n if (url != null && url.trim() && url.trim().match(urlRegex))\r\n return this.sanitizer.bypassSecurityTrustUrl(url.trim());\r\n else return null;\r\n }\r\n}","import { Injectable } from \"@angular/core\";\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { SearchMode } from '../models/search-mode.enum';\r\nimport { SearchEvent } from '../models/search-event';\r\n\r\nconst storage = {\r\n load: () => {\r\n return JSON.parse(sessionStorage.getItem('lastSearch')) || {\r\n q: [],\r\n page: 0,\r\n mode: SearchMode.simple\r\n };\r\n },\r\n save: (state: SearchEvent) => sessionStorage.setItem('lastSearch', JSON.stringify(state))\r\n};\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class SearchState {\r\n change$: BehaviorSubject = new BehaviorSubject(storage.load());\r\n\r\n constructor() {\r\n this.change$.subscribe(search => storage.save(search));\r\n }\r\n}","module.exports = \":host {\\n width: 100%;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9zaGFyZWQvY29tcG9uZW50cy9wdWJsaWNhdGlvbi1pZGVudGlmaWVyL0M6XFxQcm9qZWN0c1xcb3BlbnNjaWVuY2VcXFBvcnRhbC5XZWJBcHBsaWNhdGlvbi9zcmNcXHNoYXJlZFxcY29tcG9uZW50c1xccHVibGljYXRpb24taWRlbnRpZmllclxccHVibGljYXRpb24taWRlbnRpZmllci5jb21wb25lbnQuc2NzcyIsInNyYy9zaGFyZWQvY29tcG9uZW50cy9wdWJsaWNhdGlvbi1pZGVudGlmaWVyL3B1YmxpY2F0aW9uLWlkZW50aWZpZXIuY29tcG9uZW50LnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7RUFDSSxXQUFBO0FDQ0oiLCJmaWxlIjoic3JjL3NoYXJlZC9jb21wb25lbnRzL3B1YmxpY2F0aW9uLWlkZW50aWZpZXIvcHVibGljYXRpb24taWRlbnRpZmllci5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIjpob3N0IHtcclxuICAgIHdpZHRoOiAxMDAlO1xyXG59IiwiOmhvc3Qge1xuICB3aWR0aDogMTAwJTtcbn0iXX0= */\"","import { Component, OnInit, Input } from '@angular/core';\r\nimport { copyText } from 'src/infrastructure/utils';\r\nimport { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\r\nimport { faCopy } from '@fortawesome/free-regular-svg-icons';\r\n\r\n@Component({\r\n selector: 'publication-identifier',\r\n templateUrl: './publication-identifier.component.html',\r\n styleUrls: ['./publication-identifier.component.scss']\r\n})\r\nexport class PublicationIdentifierComponent implements OnInit {\r\n constructor() { }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n @Input()\r\n identifier: {\r\n type: string;\r\n value: string;\r\n };\r\n faCopy = faCopy;\r\n\r\n copyUrl(url: string, tooltip: NgbTooltip) {\r\n return copyText(url).subscribe();\r\n }\r\n}\r\n","module.exports = \".info {\\n font-style: italic;\\n font-size: 15px;\\n}\\n\\n.access-icon {\\n height: 15px;\\n margin: 0px 4px;\\n -webkit-transform: rotate(15deg);\\n transform: rotate(15deg);\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9zaGFyZWQvY29tcG9uZW50cy9wdWJsaWNhdGlvbi1zdWJoZWFkaW5nLWJhci9DOlxcUHJvamVjdHNcXG9wZW5zY2llbmNlXFxQb3J0YWwuV2ViQXBwbGljYXRpb24vc3JjXFxzaGFyZWRcXGNvbXBvbmVudHNcXHB1YmxpY2F0aW9uLXN1YmhlYWRpbmctYmFyXFxwdWJsaWNhdGlvbi1zdWJoZWFkaW5nLWJhci5jb21wb25lbnQuc2NzcyIsInNyYy9zaGFyZWQvY29tcG9uZW50cy9wdWJsaWNhdGlvbi1zdWJoZWFkaW5nLWJhci9wdWJsaWNhdGlvbi1zdWJoZWFkaW5nLWJhci5jb21wb25lbnQuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTtFQUNFLGtCQUFBO0VBQ0EsZUFBQTtBQ0NGOztBREVBO0VBQ0UsWUFBQTtFQUNBLGVBQUE7RUFDQSxnQ0FBQTtVQUFBLHdCQUFBO0FDQ0YiLCJmaWxlIjoic3JjL3NoYXJlZC9jb21wb25lbnRzL3B1YmxpY2F0aW9uLXN1YmhlYWRpbmctYmFyL3B1YmxpY2F0aW9uLXN1YmhlYWRpbmctYmFyLmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLmluZm8ge1xyXG4gIGZvbnQtc3R5bGU6IGl0YWxpYztcclxuICBmb250LXNpemU6IDE1cHg7XHJcbn1cclxuXHJcbi5hY2Nlc3MtaWNvbiB7XHJcbiAgaGVpZ2h0OiAxNXB4O1xyXG4gIG1hcmdpbjogMHB4IDRweDtcclxuICB0cmFuc2Zvcm06IHJvdGF0ZSgxNWRlZyk7XHJcbn0iLCIuaW5mbyB7XG4gIGZvbnQtc3R5bGU6IGl0YWxpYztcbiAgZm9udC1zaXplOiAxNXB4O1xufVxuXG4uYWNjZXNzLWljb24ge1xuICBoZWlnaHQ6IDE1cHg7XG4gIG1hcmdpbjogMHB4IDRweDtcbiAgdHJhbnNmb3JtOiByb3RhdGUoMTVkZWcpO1xufSJdfQ== */\"","import { Component, OnInit, Input } from '@angular/core';\r\nimport { Publication } from 'src/publication/models/publication';\r\nimport { LocaleService } from 'src/infrastructure/locale.service';\r\nimport { SourceType } from 'src/publication/models/source-type.enum';\r\n\r\n@Component({\r\n selector: 'publication-subheading-bar',\r\n templateUrl: './publication-subheading-bar.component.html',\r\n styleUrls: ['./publication-subheading-bar.component.scss']\r\n})\r\nexport class PublicationSubheadingBarComponent implements OnInit {\r\n\r\n constructor(\r\n public locale: LocaleService\r\n ) { }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n @Input()\r\n model: Publication;\r\n\r\n SourceType = SourceType;\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { PublicationSubheadingBarComponent } from './components/publication-subheading-bar/publication-subheading-bar.component';\r\nimport { ComponentsModule } from 'src/components/components.module';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { PublicationIdentifierComponent } from './components/publication-identifier/publication-identifier.component';\r\nimport { NgBootstrapModule } from 'src/infrastructure/ng-bootstrap.module';\r\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome';\r\n\r\n\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n TranslateModule,\r\n NgBootstrapModule,\r\n FontAwesomeModule,\r\n ComponentsModule,\r\n ],\r\n declarations: [\r\n PublicationSubheadingBarComponent,\r\n PublicationIdentifierComponent\r\n ],\r\n exports: [\r\n PublicationSubheadingBarComponent,\r\n PublicationIdentifierComponent\r\n ]\r\n})\r\nexport class SharedModule { }\r\n"],"sourceRoot":""}