diff --git a/.gitignore b/.gitignore index c656dba..25216ce 100644 --- a/.gitignore +++ b/.gitignore @@ -1,8 +1,9 @@ !primo-explore/custom/ primo-explore/tmp/ .idea/ package-lock.json -primo-explore/custom/src/js/custom.js -primo-explore/custom/src/js/custom.js.map +*custom.js +*custom*.css +*.js.map diff --git a/primo-explore/custom/src/css/custom1.css b/primo-explore/custom/src/css/custom1.css deleted file mode 100644 index a5cff76..0000000 --- a/primo-explore/custom/src/css/custom1.css +++ /dev/null @@ -1,1644 +0,0 @@ -/* Affichage des collections */ - -/* Supprime le chevauchement du titre */ -prm-collection-gallery-header .collection-header-inner.has-transparent-topbar{ - margin-top: 0px !important; -} - -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ -/**************************** Central Package CSS *****************************/ -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ - - -/*************** Navigation ******************/ - -/*Font Navigation and buttons*/ -#mainMenu > div > a, button#signInBtn, button#more-links-button, prm-topbar > div > prm-user-area-expandable > md-menu > button > span { - font-size: small !important; - font-weight: 500 !important; - color: #111 !important; -} - /*hover effect Navigation and buttons*/ - #mainMenu > div > a:hover, button#signInBtn:hover, prm-topbar > div > prm-user-area-expandable > md-menu > button:hover, button#more-links-button:hover, - prm-search-bookmark-filter > a:hover, a#favorites-button:hover, a#search-button:hover, .md-button.button-as-link:hover:not([disabled]), - .md-button.button-link:hover:not([disabled]), .md-button.button-link:focus:not([disabled]), prm-user-area-expandable .button-with-menu-arrow:hover .menu-arrow:hover:not([disabled]), - button.item-expand-button.md-button.md-primoExplore-theme.md-ink-ripple:hover:not([disabled]), - button.item-expand-button.md-button.md-primoExplore-theme.md-ink-ripple:focus:not([disabled]), - .md-button.md-lang-button:hover { - background-color: #ddd !important; - color: #111 !important; - } -/*remove capitalized text*/ -.md-button { - text-transform: none; -} - /*Menu button*/ - button.button-with-menu-arrow.md-button.md-primoExplore-theme.md-ink-ripple:hover, button#signInBtn, .md-button.button-link, - .md-button.button-as-link.link-alt-color, prm-icon md-icon, .section-title prm-icon, prm-icon.rotate-180, svg#chevron-up, - span.user-name, span.menu-arrow, .md-button.button-as-link, #sidebar-trigger > prm-icon > md-icon { - color: #111 !important; - } -/*hide hover effect on Library Logo*/ -#banner > a.md-button.md-primoExplore-theme.md-ink-ripple:hover { - background: none; -} -/*background buttons*/ -prm-search-bookmark-filter .md-button { - background-color: #fff !important; -} -/*hiding Refworks from the pulldown menu*/ -.my-refworks-ctm, .my-refworks-separator-ctm { - display: none; -} -/*switch to advanced search button*/ -button.switch-to-advanced.zero-margin.button-with-icon.md-button.md-primoExplore-theme.md-ink-ripple { - border-style: solid; - border-width: 1px; - border-radius: 5px; -} - - -.md-button.md-primary:hover:not([disabled]), .md-button.md-primary:focus:not([disabled]), prm-favorites-labels .md-chips .md-chip.toggleable-chip:not(.chip-toggled-on) .md-chip-content:hover:not([disabled]), prm-favorites-labels .md-chips .md-chip:not(.chip-toggled-on) .md-chip-content:hover:not([disabled]), .bar prm-authentication .md-button:hover:not([disabled]), button.dismiss-alert-button:hover { - color: #fff; - background-color: #111; -} - -/*switch to simple search button*/ -button.switch-to-simple.zero-margin.button-with-icon.md-button.md-primoExplore-theme.md-ink-ripple { - border-color: #f1f1f1 !important; - border-radius: 5px; - border-width: 1px; - border: solid; -} - -/*the main color border on mobile view*/ -@media (max-width: 599px) { - prm-topbar .top-nav-bar { - border-bottom-style: solid; - border-bottom-width: 8px; - } -} - -.md-button.button-as-link { - line-height: 36px; - padding: 0 6px; -} - -.md-autocomplete-suggestions li { - white-space: nowrap; -} - -/*Header menu*/ - -@media (max-width: 960px) { - prm-user-area-expandable button.user-button.user-menu-button.button-with-menu-arrow.md-button.md-primoExplore-theme.md-ink-ripple, prm-user-area-expandable-after { - display: none !important; - } - button#signInBtn { - display: block; - } - } - - primo-explore.logged-out prm-user-area-expandable md-menu { - display: none; - } - - /*Header menu: switch language*/ - - bcu-lang-switch-component { - padding-right: 16px; - } - - bcu-lang-switch-component .md-button.md-lang-button { - height: 29px; - min-height: 29px; - margin: 15px 1px !important; - min-width: 29px; - width: 29px; - line-height: 23px; - text-transform: uppercase; - border: 1px solid transparent; - border-radius: 3px; - } - - bcu-lang-switch-component .md-button.md-lang-button.active { - border-color: rgba(19, 18, 18, 0.85); - } - - bcu-lang-switch-component a { - color: rgba(255, 255, 255, 0.85); - display: inline-block; - padding-bottom: 2px; - } - - bcu-lang-switch-component a:hover { - color: rgba(255, 255, 255, 0.85); - } -/*************** Main Content ******************/ - -/*backgound of the Textboxes Homepage*/ -prm-search > div > md-content, md-card.default-card._md.md-primoExplore-theme { - background-color: #fff !important; - border-radius: 3px; -} - -/*first header of the Textboxes*/ -.cardbox h1 { - font-size: 48px; - line-height: 56px; -} - -/*second header of the Textboxes*/ -.cardbox h2 { - font-size: 32px; - line-height: 36px; -} -/*third header of the Textboxes (if needed)*/ -.cardbox h3 { - font-size: 26px; - line-height: 30px; -} - -/*removes the upper and lower space in a list */ -.cardbox ul, .cardbox ol { - margin-top: 0px !important; - margin-bottom: 0px !important; -} -/*links in the textboxes*/ -md-card-content a, prm-service-details a { - color: #222222 !important; -} - -md-card-content a, prm-service-details a, div.courier-info > span a { - text-decoration: underline !important; -} - - md-card-content a:hover, prm-service-details a:hover { - color: #111; - background-color: rgba(47, 47, 47, 0.1) !important; - } - -/*Responsive Video Frame*/ -.resp-container { - position: relative; - overflow: hidden; - padding-top: 56.25%; -} - -.resp-iframe { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - border: 0; -} - -/********Links frame *** ATTENTION: ONLY FOR CP*********/ -md-card.cardbox.default-card.quicklinksbox md-card-content { - padding: 0px; -} -md-card.cardbox.default-card.quicklinksbox div.md-button { - padding: 0 0 0 16px; -} -md-card.cardbox.default-card.quicklinksbox md-list-item._md-button-wrap._md { - border-top: #c5c5c5 1px solid ; -} -md-card.cardbox.default-card.quicklinksbox._md.md-primoExplore-theme > md-card-content > md-list > md-list-item:last-child { - border-bottom: #c5c5c5 1px solid ; -} - -.md-button._md-focused:not([disabled]), .md-button.md-focused:not([disabled]), .md-button:focus:not([disabled]) { - color: unset !important; - background-color: unset !important; -} - -/*footer layout*/ -md-card.prm-primary-bg.psfooter { - margin: 16px 0 0 0; - padding: 0 8%; -} -/*footer layout*/ -md-card.prm-primary-bg.psfooter-legal { - margin: 1px 0 0 0; - padding: 0 8%; -} -/*Responsive footer layout*/ -@media (min-width: 960px) { - - md-card-content.prm-primary-bg.layout-align-gt-sm-end-stretch.flex-gt-sm-70 { - text-align: end; - } -} -/*footer links*/ -md-icon.ps_icon, a.ps_link { - margin-right: 5%; - text-decoration: underline; -} - -/*md-icon.ps_icon:hover, a.ps_link:hover, a.ps_link.legal:hover, span.legal a:hover { - background-color: rgba(61,110,148,.1) !important; - }*/ - - -/*footer text*/ -md-card-content.prm-primary-bg { - font-weight: 300; -} - - -/*links in the legal part of the footer*/ -a.ps_link.legal, span.legal { - font-size: 14px; - font-weight: 300; -} - - /************************************************************************************************ -span.legal { - color: #14413c; -} -*/ - span.legal > a { - /*color: #14413c;*/ - font-weight: 600; - } - -/*main container width for footer positioning*/ -prm-static.md-padding.flex { - min-width: 100%; - padding: 0; -} - -/*mainly white background*/ -.prm-primary-bg.prm-hue1, prm-atoz-search-bar.prm-hue1, prm-browse-search-bar.prm-hue1, prm-collection-gallery-header .prm-hue1.collection-header-inner, prm-newspapers-search-bar.prm-hue1, prm-search-bar.prm-hue1, prm-spinner.prm-hue1.overlay-cover.light-on-dark:after, prm-tags-search-bar.prm-hue1, prm-topbar .top-nav-bar, prm-tree-nav prm-spinner .prm-hue1.diamond { - background-color: #fff !important; -} - - -/*font color on white background*/ -.hoverable-over-dark, .md-button.button-over-dark, prm-main-menu[menu-type=full] .md-button.md-focused, prm-main-menu[menu-type=full] .md-button .md-input-container-dummy > .md-select-dummy:focus, prm-main-menu[menu-type=full] .md-button:focus, prm-main-menu[menu-type=full] .md-button:hover, prm-main-menu[menu-type=full] .md-button md-select:focus, prm-main-menu[menu-type=full] .overlay-menu-item.md-focused, prm-main-menu[menu-type=full] .overlay-menu-item .md-input-container-dummy > .md-select-dummy:focus, prm-main-menu[menu-type=full] .overlay-menu-item:focus, prm-main-menu[menu-type=full] .overlay-menu-item:hover, prm-main-menu[menu-type=full] .overlay-menu-item md-select:focus, prm-main-menu[menu-type=full] md-button:focus, prm-main-menu[menu-type=full] md-button:hover, prm-topbar .md-button, prm-user-area .md-button.user-menu-button, prm-user-area md-fab-toolbar ._md-fab-action-item .md-button, prm-user-area md-fab-toolbar ._md-fab-action-item md-input-container, prm-user-area md-fab-toolbar .md-fab-action-item .md-button, prm-user-area md-fab-toolbar .md-fab-action-item md-input-container { - color: #222 !important; -} - -/*************** Brief results ******************/ - -/*color of the Alertbar*/ -.bar.alert-bar, .classic-input .search-scope, .prm-alert-bg { - /*background-color: #8dd8d8 !important;*/ - border: none !important; -} - -/*backgound search results boxes*/ -.list-item-wrapper { - background-color: #f9f9f9; -} -/*Title color*/ -prm-brief-result .item-title span { - color: #333; -} - - prm-brief-result .item-title span:hover { - color: #111; - background-color: rgba(47, 47, 47, 0.1) !important; - } - -/*remove hover effect from title links*/ -.md-button.arrow-link-button .button-content:focus, .md-button.arrow-link-button .button-content:hover, .md-button.arrow-link-button .hover.button-content, .md-button.arrow-link-button:focus .button-content, .md-button.arrow-link-button:hover .button-content, .recommendations-title.hover > span > span, .recommendations-title:hover > span > span, a.hover, a:focus, a:hover, prm-chapters-and-reviews md-card > .md-button:focus .item-title span, prm-chapters-and-reviews md-card > .md-button:hover .item-title span, prm-citation-trails-item.active-item md-card > .md-button:focus .item-title span, prm-citation-trails-item.active-item md-card > .md-button:hover .item-title span, prm-tags-list .md-chips .md-chip .md-chip-content:hover strong, prm-tags-list .md-chips md-chip .md-chip-content:hover strong, prm-tags-list md-chips .md-chip .md-chip-content:hover strong, prm-tags-list md-chips md-chip .md-chip-content:hover strong { - box-shadow: none !important; -} - -/*background color of bookmarked items*/ -.list-item-wrapper .item-bookmarked, .list-item-wrapper .item-bookmarked:hover, .prm-highlight, .prm-highlight.prm-hue1, prm-breadcrumbs .md-chip.persistent-facet, prm-breadcrumbs .prm-hue1.md-chip.persistent-facet { - background-color: #ddd !important; -} - -/*hover effect on all Links*/ -.md-button.arrow-link-button .button-content:focus, .md-button.arrow-link-button .button-content:hover, .md-button.arrow-link-button .hover.button-content, -.md-button.arrow-link-button:focus .button-content, .md-button.arrow-link-button:hover .button-content, .prm-links-background.prm-hue-1, -.recommendations-title.hover > span > span, .recommendations-title:hover > span > span, a.hover, a:focus, a:hover, -prm-chapters-and-reviews md-card > .md-button:focus .item-title span, prm-chapters-and-reviews md-card > .md-button:hover .item-title span, -prm-citation-trails-item.active-item md-card > .md-button:focus .item-title span, prm-citation-trails-item.active-item md-card > .md-button:hover .item-title span, -prm-tags-list .md-chips .md-chip .md-chip-content:hover strong, prm-tags-list .md-chips md-chip .md-chip-content:hover strong, -prm-tags-list md-chips .md-chip .md-chip-content:hover strong, prm-tags-list md-chips md-chip .md-chip-content:hover strong { - color: #222 !important; -} - -div.custom-links-container.layout-wrap.layout-align-sm-start-start.layout-align-center-start.layout-row > div > a:hover { - background-color: #6b6b6b !important; -} - -/*Facet titles*/ -span.section-title-header:hover { - color: #8a8a8a !important; -} - -/*Facet "show more" button*/ -.sidebar-section .md-button.button-as-link.link-alt-color:hover { - background-color: rgba(17, 17, 17, 0.17) !important; -} - -/*page select buttons*/ -a.md-mini.md-button.md-primoExplore-theme.md-ink-ripple:hover { - color: white !important; -} - -/*underlined search results*/ -/*.text-highlight, mark { - box-shadow: inset 0 -0.15em 0 0 #8dd8d8; -}*/ - -/*versions link and other*/ -.getit, .md-button.arrow-link-button prm-search-result-frbr-line .button-content > prm-icon:first-child, .prm-notice, .status-maybe, .worldcat, [class*=_more], [class*=_unknown], [class*=check_], [class*=does_not_exist], [class*=may_], [class*=NFT], prm-search-result-frbr-line .md-button.arrow-link-button .button-content > prm-icon:first-child, prm-search-result-frbr-line a > prm-icon:first-child, prm-service-links a { - color: #222 !important; -} -/*icon color and text color in request forms*/ -.prm-primary-color, .request-form md-input-container label, .request-form md-input-container label:not(.md-no-float):not(._md-container-ignore), .request-form md-input-container md-select .md-select-value.md-select-placeholder, .request-form md-input-container .md-input-container-dummy > .md-select-dummy .md-select-value.md-select-placeholder, .request-form md-input-container md-select ._md-select-value._md-select-placeholder, .request-form md-input-container .md-input-container-dummy > .md-select-dummy ._md-select-value._md-select-placeholder, .result-item-actions .md-icon-button, .result-item-actions .more-options-button, prm-add-query-to-saved-searches .custom-button, prm-pre-filters md-input-container.is-active, .md-autocomplete-suggestions .suggestion-scope, md-tab-content .tab-content-header md-input-container md-select-value .md-text { - color: #222 !important; -} -/*space between item details in Fullview*/ -#item-details > div > div { - margin-bottom: .8em !important; -} - -/*Items expand*/ - -@media (max-width: 960px) { -prm-location-items .md-list-item-text.layout-wrap.layout-row.flex { - flex-direction: column; -} -prm-location-items h3, prm-location-items h4 { - margin:10px 0 !important; -} -prm-location-items > md-list > md-list-item > div > div.md-list-item-text > div.weak-text > div > div > p { - margin: 4px 18px !important; - display: list-item; -} -prm-location-items > md-list > md-list-item > div > div > div.layout-wrap { - flex-direction: row !important; - justify-content: flex-start !important; - max-width: 100% !important; -} -prm-location-items > md-list > md-list-item > div > div > div > div > prm-service-button > button { - box-shadow: inset 0 -0.15em 0 0 #8dd8d8; -} - -} - -/* Hide "search inside" for print journals */ -.search-within-p-only { display:none } - -/*fullview background of the left part*/ -.md-dialog-container.fixed-container { - background-color: #444 !important; -} - -/*background color of the signin window and the fullscreen navigation*/ -md-backdrop._md-dialog-backdrop.md-opaque.md-primoExplore-theme { - background-color: #1f1f1f !important; -} -/*text color of the signin window and the fullscreen navigation*/ -prm-main-menu[menu-type=full] .md-button .md-headline, prm-main-menu[menu-type=full] .overlay-menu-item .md-headline, .light-on-dark-dialog .md-button.button-as-link, .light-on-dark-dialog .md-button.button-confirm, md-dialog.light-on-dark-dialog md-list md-list-item.list-login .md-button, md-dialog.light-on-dark-dialog a:hover { - color: #fff !important; -} -/*hiding the Library Logo in the login window*/ -.login-header { - display: none !important; -} -/*login-box make arrows clickable*/ -prm-login button.md-no-style.md-button.md-primoExplore-theme.md-ink-ripple { - z-index: 100; -} -prm-login .md-list-item-inner prm-login-item a.md-primoExplore-theme { - z-index: 1000; -} -prm-login .md-button.md-no-style:hover { - color:black; -} -prm-stand-alone-login button.md-no-style.md-button.md-primoExplore-theme.md-ink-ripple { - z-index: unset; -} - -.login-card md-list-item.login-brighter-dialog prm-login-item { - width:100%; -} - -/*alertbar for the courier info*/ -.courier-info { - margin: 0px 8px; -} - -.courier-info.bar.alert-bar { - height: unset; - margin: 6px 8px; - padding: .5em .5em 0.25em; - text-align: center; -} - -/*Library info icon*/ -slsp-i-button-component > div > span > a > img { - vertical-align: middle; - max-width: 30px; - margin: 4px 12px; -} - -/*Library card Personal details display*/ -#personalDetails > md-card-content > div { - flex-flow: column; -} - -#personalDetails .md-input-has-value.layout-column { - min-width: 400px; -} - -prm-personal-info-after { - display: flex; -} - -slsp-edit-personal-details-component#SLSPeditPersonalDetails { - background-color: #f0f0f0; - padding-top: 30px; -} - -/*Library card: IZ selector for mobiles*/ -@media (max-width: 599px) { -div.md-select-menu-container.md-primoExplore-theme.md-active.md-clickable, prm-account prm-linked-user-selector { - font-size: 16px !important; -} -} - -/*Library card: Show not renewable messages in list of loans*/ -prm-loan .md-list-item-text.md-list-item-with-checkbox.layout-wrap.layout-row.flex { - order: 1; - /*flex-flow: column;*/ - max-width: 75%; -} -prm-loan-after { - order: 2; - align-self: baseline; - flex: 15%; -} -prm-loan-after span.md-subhead { - font-size: small; - line-height: 18px; - color: #d84f26; - padding: 22px 0; -} -prm-loan > div.align-self-stretch.flex-xs-50 { - order: 4; -} - -prm-loan > div.md-list-item-text.md-list-item-with-checkbox.layout-wrap.layout-row.flex > div:nth-child(3) { - min-width: 100%; -} -prm-loan > div.md-list-item-text.md-list-item-with-checkbox.layout-wrap.layout-row.flex > div:nth-child(4) { - min-width: 50%; - margin: 10px 0; -} -prm-loan > div.md-list-item-text.md-list-item-with-checkbox.layout-wrap.layout-row.flex > div:nth-child(5) { - min-width: 43%; - justify-content: flex-end; - align-items: baseline; -} -#accountoverview > md-tabs > md-tabs-content-wrapper > md-tab-content:nth-child(2) > div > div { - flex-direction: column; -} -prm-loan .not-renewable { - padding: 6px 0px 6px 6px; - display: block; - border: 1px #d23333 solid; - max-width: min-content; -} - -/*Library card: hide not renewable messages in list of loans for mobiles*/ -@media (max-width: 599px) { -slsp-renew-item-text-component { - display: none; -} -} - -/******************************************************************************/ -/************************************ Full display ****************************/ -/******************************************************************************/ - -/*Back buttons*/ - -md-tabs.tabs-as-app .back-button, prm-location-holdings .md-button.button-as-link, prm-location-items .button-link { - box-shadow: none; - color: #111111 !important; - background: rgba(17, 17, 17, 0.20) !important; - line-height: 24px; - border: 1px solid rgba(0, 0, 0, 0.59); -} - -md-tabs.tabs-as-app:hover .back-button:hover, prm-location-holdings .md-button.button-as-link:hover:not([disabled]), prm-location-items .button-link:hover:not([disabled]) { - color: #111111 !important; - background-color: rgba(17, 17, 17, 0.10) !important; -} - -/*Buttons margin*/ - -prm-request-services, prm-opac, prm-location-holdings .md-button.button-as-link { - margin-top: 5px; -} - -/* Locations filter by default; hide filter button */ -prm-locations button[ng-if='$ctrl.displayFiltersButton && !$ctrl.locationsPrefilterActive']{ - display: none !important; -} -prm-location-items button[ng-if='($ctrl.isFilter || $ctrl.isFiltered) && $ctrl.isAnyFilterFilled()']{ - display: none !important; -} - - -/* Location filter "Clear" button */ - -prm-locations-filter .md-button.button-as-link:hover:not([disabled]) { - -background-color: rgba(17, 17, 17, 0.10) !important; - -} - -/*filter bar*/ - -prm-locations-filter md-select { - margin-top:1px; -} - -prm-location-items prm-service-button .md-button.button-as-link { - padding:0 6px !important; - box-shadow:none; - line-height:28px; -} - -.full-view-container { - overflow-y: hidden; - margin-bottom: 50px; -} - -html#primoExploreRoot { - overflow-y: auto !important; -} - -/*FullView - Left Navigation */ -prm-full-view .services-index-under{ - min-width: 7em; -} -prm-full-view .services-index-under .md-button{ - width: 100%; - /* border: 1px solid #c3c3c3; */ - margin: 1px 0!important; - text-overflow: clip; - padding-right: 0; - white-space: normal; - line-height: 20px; - padding: 7px 5px; -} -prm-full-view .services-index-under .md-button span{ - text-transform: none; -} - -/*Full view Resource sharing */ - -#getit_link1_0 > div > prm-full-view-service-container > div.section-body > div { - display: flex; - flex-direction: column; -} - -prm-opac { - order: 1; -} - -prm-alma-other-members { - order: 2; - display: grid; -} - -alma-htgi-svc { - order: 3; -} - -primo-explore.logged-out alma-htgi-svc, primo-explore.alert alma-htgi-svc { - order: 0 !important; -} - -.medium-uppercase-bold { - text-transform: none; - font-size: 1em; -} - -/*Full display Resource sharing expand section*/ - -prm-alma-other-units button.layout-fill, prm-alma-other-members button.layout-fill { - height: auto; - min-height: auto; -} - -/* Full display sections order */ - -#full-view-container > *:first-child { - display: flex; - flex-direction: column; -} - -#brief { - order: 0 !important; - margin-bottom: -40px; -} - -#citationTrails { - order: 1 !important; - margin-bottom: -30px; -} - -#searchWithinJournal { - order: 2 !important; - margin-bottom: -30px; -} - -#getit_link1_0 { - order: 3 !important; - margin-bottom: -30px; -} - -#getit_link1_1 { - order: 4 !important; - margin-bottom: -30px; -} - -#action_list { - order: 5 !important; - margin-bottom: -30px; -} - -#details { - order: 6 !important; - margin-bottom: -30px; -} - -#links { - order: 7 !important; - margin-bottom: -30px; -} - -#moreFromTheSameCourse { - order: 8 !important; - margin-bottom: -30px; -} - -#moreFromTheSameCollection { - order: 9 !important; - margin-bottom: -30px; -} - -#virtualBrowse { - order: 10 !important; - margin-bottom: -30px; -} - -/* Change of links in left navigation bar ENG */ - -[aria-label="Top"] { - order: 0 !important; -} - -[aria-label="Citations"] { - order: 1 !important; -} - -[aria-label="Search inside"] { - order: 2 !important; -} - -[aria-label="View Online"] { - order: 3 !important; -} - -[aria-label="Loan and request options"] { - order: 4 !important; -} - -[aria-label="Send to"] { - order: 5 !important; -} - -[aria-label="Details"] { - order: 6 !important; -} - -[aria-label="Links"] { - order: 7 !important; -} - -[aria-label="Course"] { - order: 8 !important; -} - -[aria-label="Collection"] { - order: 9 !important; -} - -[aria-label="Virtual Browse"] { - order: 10 !important; -} - -/* Change of links in left navigation bar GER */ - -[aria-label="Top"] { - order: 0 !important; -} - -[aria-label="Zitationen"] { - order: 1 !important; -} - -[aria-label="Suche innerhalb"] { - order: 2 !important; -} - -[aria-label="Online ansehen"] { - order: 3 !important; -} - -[aria-label="Ausleih- und Bestelloptionen"] { - order: 4 !important; -} - -[aria-label="Senden an"] { - order: 5 !important; -} - -[aria-label="Details"] { - order: 6 !important; -} - -[aria-label="Links"] { - order: 7 !important; -} - -[aria-label="Seminar"] { - order: 8 !important; -} - -[aria-label="Sammlung"] { - order: 9 !important; -} - -[aria-label="Virtuelles Regal"] { - order: 10 !important; -} - -/* Change of links in left navigation bar FRE */ - -[aria-label="Haut"] { - order: 0 !important; -} - -[aria-label="Citations"] { - order: 1 !important; -} - -[aria-label="Rechercher dans"] { - order: 2 !important; -} - -[aria-label="Consulter en ligne"] { - order: 3 !important; -} - -[aria-label="Options de prêt et de demande"] { - order: 4 !important; -} - -[aria-label="Envoyer vers"] { - order: 5 !important; -} - -[aria-label="Détails"] { - order: 6 !important; -} - -[aria-label="Liens"] { - order: 7 !important; -} - -[aria-label="Séminaire"] { - order: 8 !important; -} - -[aria-label="Collection"] { - order: 9 !important; -} - -[aria-label="Etagère virtuelle"] { - order: 10 !important; -} - -/* Change of links in left navigation bar ITA */ - -[aria-label="Top"] { - order: 0 !important; -} - -[aria-label="Citazioni"] { - order: 1 !important; -} - -[aria-label="Cerca in"] { - order: 2 !important; -} - -[aria-label="Visualizza online"] { - order: 3 !important; -} - -[aria-label="Opzioni di prestito e richiesta"] { - order: 4 !important; -} - -[aria-label="Invia a"] { - order: 5 !important; -} - -[aria-label="Dettagli"] { - order: 6 !important; -} - -[aria-label="Link"] { - order: 7 !important; -} - -[aria-label="Corso"] { - order: 8 !important; -} - -[aria-label="Collezione"] { - order: 9 !important; -} - -[aria-label="Scorri virtualmente"] { - order: 10 !important; -} - -/******************************************************************************/ -/************************************ Help Page *******************************/ -/******************************************************************************/ -#help img { - max-width: 100%; - height: auto; -} - -img.icon_up1 { - width: 16px; - float: right; - margin: 13px 2px; -} - -img.icon_up2 { - width: 10px; - float: right; - margin: 4px; -} - -a > h3:hover { - background-color: #eee !important; -} - -/******************************************************************************/ -/************************************ Collections *****************************/ -/******************************************************************************/ - -/*Collections navigation bar*/ - -prm-collection-navigation-breadcrumbs-item .md-button.button-as-link.link-alt-color { - box-shadow: none; - color: #ffffff !important; - background: #1111117a !important; - line-height: 24px; - } - -prm-collection-navigation-breadcrumbs-item .md-button.button-as-link.link-alt-color:hover { - -color:#ffffff !important; -background-color: #11111152 !important; } - -/******************************************************************************/ -/****************** SLSP "special" external resources ***************************/ -/******************************************************************************/ - -.slsp-archives md-list-item{ - cursor: pointer; -} -.slsp-archives .md-list-item-inner span { - padding-left: 2em; -} -.slsp-archives md-list md-list-item .md-button{ - color: #3d6e94; - font-size: 16px; -} -.slsp-archives md-list md-list-item .md-button:hover:not([disabled]), -.slsp-archives md-list md-list-item .md-button:focus:not([disabled]) { - background-color: transparent; - color: #3d6e94; - text-decoration: underline; -} -.slsp-archives-additional-hint{ - justify-content: center; - display: flex; - padding: 1em; - background-color: #f7eda3; - border-color: #ede49e; - margin-bottom: 1em; - padding-left: 2em; - box-shadow: 0 1px 0 0 rgb(0 0 0 / 3%), 0 5px 5px -3px rgb(0 0 0 / 7%); -} -/* mfa, tma */ -.slsp-archives-hide alma-htgi-svc > * { - display: none; -} -.slsp-archives-hide alma-htgi-svc-after { - display: block; -} -/* hsa */ -.slsp-archives-hide prm-alma-viewit > * { - display: none; -} -.slsp-archives-hide prm-alma-viewit-after { - display: block; -} -/* availability-line HSA, if no online resource */ -prm-search-result-availability-line.slsp-hsa-no-online prm-icon{ - display:none; -} -prm-search-result-availability-line.slsp-hsa-no-online .availability-status { - color: gray; -} - -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ -/********************** End of the Central Package CSS ************************/ -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ - -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ -/********************** Start of the Local Package CSS ************************/ -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ - - -/******************************************************************************/ -/********************** Primary colour ****************************************/ -/******************************************************************************/ - - -/*****************This two entries are the background of the primary color*******************/ -.prm-primary-bg, prm-atoz-search-bar, prm-browse-search-bar, prm-collection-gallery-header .collection-header-inner, prm-search-bar, prm-newspapers-search-bar, prm-spinner.overlay-cover.light-on-dark:after, prm-tags-search-bar, prm-tree-nav prm-spinner .diamond, .prm-primary-bg, md-checkbox.md-checked .md-icon, md-tabs md-ink-bar, md-radio-button.md-checked .md-on, button.switch-to-simple, .md-button.button-confirm, -prm-request-services .md-button.button-as-link, prm-location-items md-list prm-service-button .md-button.button-as-link { - background-color: #ff0000 !important; -} - -@media (max-width: 599px) { - prm-topbar .top-nav-bar { - border-color: #ff0000 !important; - } -} - -/*****************This entry is the mouse over background of the links and buttons*******************/ -md-card.prm-primary-bg.psfooter > md-card-content a:hover, md-icon.ps_icon:hover, a.ps_link:hover, a.ps_link.legal:hover, span.legal a:hover, button.switch-to-advanced:hover, button.switch-to-simple:hover, .md-button.button-confirm:hover, .md-button.button-as-link:hover:not([disabled]) { - background-color: #ae0010 !important; -} - -/*****************This two entries are the font color of the primary color*******************/ -.prm-primary-bg, prm-atoz-search-bar, prm-browse-search-bar, prm-collection-gallery-header .collection-header-inner, prm-newspapers-search-bar, -prm-spinner.overlay-cover.light-on-dark:after, prm-tags-search-bar, prm-tree-nav prm-spinner .diamond, .prm-primary-bg, md-checkbox.md-checked .md-icon:after, .md-button.switch-to-advanced, button.switch-to-simple, span.legal, span.legal > a, a.ps_link.legal, .ps_icon, md-card.prm-primary-bg.psfooter > md-card-content a, .md-button.button-confirm, prm-request-services .md-button.button-as-link, prm-request-services .md-button.button-as-link:hover:not([disabled]), prm-service-button .md-button.button-as-link:hover:not([disabled]), prm-location-items md-list prm-service-button .md-button.button-as-link { - color: #fff !important; -} - -button.switch-to-advanced.zero-margin.button-with-icon.md-button.md-primoExplore-theme.md-ink-ripple { - border-color: #c1c1c1 !important; -} - -/*****************selection color of the primary color*****************/ -.prm-primary-bg ::selection { - background: #ffbe8f; -} - - -/******************************************************************************/ -/********************** Secondary colour **************************************/ -/******************************************************************************/ - -/*****************This two entries are the background of the secondary color*******************/ -.bar.alert-bar, .classic-input .search-scope, .prm-alert-bg { - background-color: #ffcccc !important; -} - -.text-highlight, mark, prm-location-items > md-list > md-list-item > div > div > div > div > prm-service-button > button { - box-shadow: inset 0 -0.15em 0 0 #ff0000; -} - -/*****************This entry is the mouse over background of the links and buttons (secondary-color)*******************/ -/*.bar prm-authentication .md-button:hover:not([disabled]),*/ -div.alert-bar .md-button:hover:not([disabled]), slsp-edit-personal-details-component a.bar.alert-bar:hover { - background-color: #ffcccc !important; -} - - -/*****************This entry is the font color of the secondary color*******************/ -.bar.alert-bar, .classic-input .search-scope, .prm-alert-bg, .bar prm-authentication .md-button, button.dismiss-alert-button, div.courier-info > span a { - color: #111111 !important; -} - -/*****************selection color of the secondary color**********************************/ -.bar.alert-bar ::selection { - background: #ffbe8f; -} - -/*********************************/ -/* CSS pour les bases de données */ -/*********************************/ - -prm-databases-categorize h2, -prm-databases-categorize prm-tree-nav{ - width: 220px; - max-width: 220px; -} - -@media only screen and (max-width: 1100px){ - prm-databases-categorize h2, - prm-databases-categorize prm-tree-nav{ - width: 180px !important; - max-width: 180px !important; - } -} - -/*****************Selected text color*******************/ - -::selection { - background: #ffbe8f; /* WebKit/Blink Browsers */ -} -::-moz-selection { - background: #ffbe8f; /* Gecko Browsers */ -} - -/*****************This entry remove default color from various texts*******************/ - -md-dialog.light-on-dark-dialog .md-list[class$="-line"] md-list-item .md-list-item-text .list-item-title, md-dialog.light-on-dark-dialog .md-list[class$="-line"] md-list-item .md-list-item-text h3, md-dialog.light-on-dark-dialog .md-list[class$="-line"] md-list-item > .md-no-style .md-list-item-text .list-item-title, md-dialog.light-on-dark-dialog .md-list[class$="-line"] md-list-item > .md-no-style .md-list-item-text h3, md-dialog.light-on-dark-dialog .md-list md-list-item .md-list-item-text .list-item-title, md-dialog.light-on-dark-dialog .md-list md-list-item .md-list-item-text h3, md-dialog.light-on-dark-dialog .md-list md-list-item > .md-no-style .md-list-item-text .list-item-title, md-dialog.light-on-dark-dialog .md-list md-list-item > .md-no-style .md-list-item-text h3, md-dialog.light-on-dark-dialog md-list md-list-item .md-list-item-text .list-item-title, md-dialog.light-on-dark-dialog md-list md-list-item .md-list-item-text h3, md-dialog.light-on-dark-dialog md-list md-list-item > .md-no-style .md-list-item-text .list-item-title, md-dialog.light-on-dark-dialog md-list md-list-item > .md-no-style .md-list-item-text h3, md-button.arrow-link-button md-dialog.light-on-dark-dialog .button-content, md-dialog.light-on-dark-dialog .md-button.arrow-link-button .button-content, md-dialog.light-on-dark-dialog a{ - color: #ffcccc !important; -} - -/*Bouton pour confirmer une demande*/ -prm-request button.md-button.button-confirm, span[translate="fulldisplay.locations.showmore"], .courier-info .button-confirm { - background-color: #080 !important; - border-radius: 2px; - border-style: none; -} -prm-request button.md-button.button-confirm:hover, span[translate="fulldisplay.locations.showmore"]:hover, .courier-info .button-confirm:hover { - background-color: #050 !important; -} - -span[translate="fulldisplay.locations.showmore"]{ - line-height: 24px !important; - padding: 5px 8px; - margin: 4px 0 !important; - color: white; - border-radius: 2px; -} -/* Suppression du fond du bouton + d'exemplaires */ -prm-location-items .md-button.button-link:hover:not([disabled]){ - background-color: transparent !important; - border-style: none !important; -} - -button[ng-hide="!$ctrl.currLoc.isMore"] { - background-color: transparent !important; - border-style: none !important; -} -/* Fix SLSP pour la couleur du bouton secondaire */ -.bar prm-authentication .md-button:hover:not([disabled]), button.dismiss-alert-button:hover{ - background-color:#ffdddd !important; - border: 1px solid #ae0010; -} - -/* Fix SLSP pour le bouton ""élargir" */ -button.item-expand-button.md-button.md-primoExplore-theme.md-ink-ripple{ - background-color: #D3D3D3!important; -} - -/*****************This entry remove default color from various forms*******************/ - -.md-input-color-underline, .new-result-item .list-item-count, .prm-secondary-bg.prm-hue1, -md-input-container.empty-select-on-init:not(.md-input-focused) .md-input-container-dummy > .md-select-dummy md-select-value::after, -md-input-container.empty-select-on-init:not(.md-input-focused) md-select md-select-value::after, md-input-container::after, -md-progress-linear[md-mode="indeterminate"].header-progress-bar .prm-hue1.md-bar, md-radio-button.md-checked ._md-on, -md-radio-button.md-checked .md-on, md-tabs md-ink-bar, prm-tags-list .md-chips ._md-chip-input-container::after, -prm-tags-list .md-chips .md-chip-input-container::after, prm-tags-list md-chips ._md-chip-input-container::after, -prm-tags-list md-chips .md-chip-input-container::after { - background-color: #ff0000 !important; -} - -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ -/********************** Start of the EPFL Package CSS ************************/ -/******************************************************************************/ -/******************************************************************************/ -/******************************************************************************/ - -/* Suppression configuration master template */ -/* prm-request-services .md-button.button-as-link{ - background-color: unset !important; -} */ - -/* hover for the service button */ -/* .md-button.button-as-link:hover:not([disabled]){ - background-color: unset !important; -} */ - -/* Design of action buttons when active */ -.md-button.md-primary:hover:not([disabled]), .md-button.md-primary:focus:not([disabled]), prm-favorites-labels .md-chips .md-chip.toggleable-chip:not(.chip-toggled-on) .md-chip-content:hover:not([disabled]), prm-favorites-labels .md-chips .md-chip:not(.chip-toggled-on) .md-chip-content:hover:not([disabled]), .bar prm-authentication .md-button:hover:not([disabled]), button.dismiss-alert-button:hover { - color: #fff !important; - background-color: #111 !important; -} - -/* Button to return to localisations */ -md-tabs.tabs-as-app .back-button { - background-color: #777 !important; - line-height: 24px !important; - min-height: 24px !important; - margin: 4px 0 !important; -} - -/* Color white for the button back to locations */ -md-tabs.tabs-as-app .back-button{ - color: #fff !important; -} - -md-tabs.tabs-as-app .back-button:hover:not([disabled]) { - background-color: #555 !important; -} - -/* Background of actions button when clicked */ -#scrollActionList button[aria-selected="true"] { - color: #fff; - background-color: #3a3a3a; -} - -/* Suppress blue border of input search box */ -input#searchBar{ - outline: none; -} - -/* Color of the close menu button */ -#mainMenuFullCloseButton:not(:hover){ - color: white!important; -} - -#mainMenuFullCloseButton:hover{ - color: #222 !important; - background: white !important; -} - - -md-card.psfooter, md-card.psfooter-legal, -md-card.psfooter > md-card-content.prm-primary-bg, md-card.psfooter-legal > md-card-content.prm-primary-bg, -md-card.prm-primary-bg.psfooter > md-card-content a:hover, md-card.prm-primary-bg.psfooter-legal > md-card-content a:hover{ - background-color: #d6d6d6 !important; -} - -md-card.psfooter md-card-content, md-card.psfooter-legal md-card-content, -md-card.prm-primary-bg.psfooter > md-card-content a, md-card.prm-primary-bg.psfooter-legal > md-card-content a, -md-card.prm-primary-bg.psfooter-legal span.legal { - color: #3a3a3a !important; -} - -md-card.prm-primary-bg.psfooter > md-card-content a:hover, md-card.prm-primary-bg.psfooter-legal > md-card-content a:hover { - color: #ff0000 !important; -} - -/* Navigation Links on fullview notices */ -prm-full-view .services-index-under{ - min-width: 7em; -} -prm-full-view .services-index-under .md-button{ - background-color: white; - width: 100%; - border: 1px solid #c3c3c3; - margin: 1px 0!important; - text-overflow: clip; - padding-right: 0; - white-space: normal; - line-height: 20px; - padding: 5px; -} -prm-full-view .services-index-under .md-button span{ - text-transform: none; -} - -/* Couleur rouge pour les logos téléphone, mail, etc. */ -.puce{ - text-decoration: none !important; -} -.puce > span:first-child{ - color: #ff0000; - fill: #ff0000; -} -h1.md-headline{ - font-size: 36px; - line-height: 42px; -} -h2.md-headline{ - font-size: 28px; - line-height: 34px; -} -md-content.epfl-row { - justify-content: center; -} -.epfl-row md-card-title{ - flex: none; -} -.epfl-row md-card { - height: 100%; -} -.epfl-social a{ - text-decoration: none !important; -} - -/* Augmente l'espace pour réduire la probabilité de clic sur le lien */ -prm-login md-list md-list-item:first-child p[translate="parallel.login.description1"]{ - margin-top:15px !important; -} - -/* Réduit la taille du lien Alma */ -prm-login md-list md-list-item:last-child { - font-size: x-small !important; -} - -/* Rendre les chevrons cliquables */ -md-dialog>prm-login button.md-no-style.md-button.md-primoExplore-theme.md-ink-ripple{ - z-index: 100; -} - -/*********************************/ -/* CSS pour le compte du lecteur */ -/*********************************/ - -/* Liste des institutions sur le compte du lecteur */ - -/* Ajoute le rouge EPFL sur l'icône d'activité et sur l'institution sélectionnée*/ -/* Egalement sur l'icône de l'alerte du tab du compte lecteur */ -prm-account md-list-item.is-selected h3.institution-name, -prm-account md-tab-item prm-icon[ng-if="$ctrl.messagesGeneralAlert"], -prm-account md-list-item prm-icon { - color: red !important; -} - -/* Le fond gris englobe l'icône */ -prm-account-overview .main-institution-list md-list-item:focus-within, -prm-account-overview .main-institution-list md-list-item:hover { - background-color: #3a3a3a !important; -} - -/* Ajoute le rouge EPFL sur l'IZ sélectionnée */ -prm-account-overview md-list-item.is-selected, -prm-account-overview md-list-item.is-selected span{ - color: red !important; -} - -.feedbacklink md-icon{ - height: 20px; - width: 20px; - min-height: 20px; - min-width: 20px; -} -prm-alma-viewit-after .bar{ - height: auto; -} - - -/* Empêcher les retours à la ligne pour les cotes */ -span[ng-if="$ctrl.location.callNumber"]{ - white-space: nowrap -} - - -.btn-account { - padding: 24px; -} -.btn-account md-card-content.bar{ - margin: 0 0 12px 0!important; - border: solid #ddd 1px !important; - background-color: #fff !important; - min-width: 100%; - display: table; - padding: 0 10px !important; - margin: 0 0 12px 0 !important; -} -.btn-account a md-card-content.bar:hover{ - background-color: #ddd !important; -} -.btn-account .md-subhead{ - font-size: inherit; - display: table-cell; - vertical-align: middle; - padding-left: 15px; - box-sizing: border-box; -} -.btn-account .md-subhead{ - min-height: 100%; -} -.btn-account prm-icon{ - vertical-align: middle; - margin-left: : 10px; - width: 20px; - height: 20px; - display: table-cell; -} - -/*****************This entry adapt the message fee*******************/ - -.feemsg { - background-color: #ffcccc; - border-radius: 3px; - padding: 8px; -} - -.feemsg>div { - margin-left: 10px; -} - -.bigfont { - font-size: 20px; -} - -/* Supprimer le fonds rouge des boutons */ -prm-request-services .md-button.button-as-link,prm-request-services .md-button.button-as-link:hover:not([disabled]){ - background-color: transparent!important; -} - -/* Conserve le blanc du bouton back */ -md-tabs.tabs-as-app:hover .back-button:hover{ - color: white !important; -} - - -/* Bouton de la recherche avancée */ -.search-switch-buttons span{ - font-variant: small-caps; - font-size: 1.15em; -} -.search-switch-buttons button{ - border: none !important; -} - -/* Message d'alerte */ -prm-search-bar>div { - height: inherit !important; - min-height: inherit !important; -} -prm-search-bar-after>div { - background-color: #fff !important; - margin-top: 20px; - padding: 10px 15px; -} -prm-search-bar-after p { - margin: 0 12px; -} -.info-symbol::before { - content: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 34 34' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Crect fill='%234a90e2' width='34' height='34' rx='4'/%3E%3Cpath d='M17 25V15M17 13V9' stroke='%23FFF' stroke-width='4'/%3E%3C/g%3E%3C/svg%3E"); - width: 24px; - height: 24px; - position: absolute; - display: inline-block; - top: 50%; - left: .6rem; - width: 1.6rem; - height: 1.6rem; - margin-top: -.8rem; -} -.info-symbol { - position: relative; -} -.info-symbol div { - margin-left: 50px; -} -prm-search-bar-after p { - padding: .25em 0 .25em; - margin: 0; -} -prm-search-bar-after a { - color: black; - text-decoration: underline; -} - -/* Empêcher que le blanc de l'effet hover masque la notice */ -prm-search-result-availability-line-after { - z-index: 8; - position: relative; -} -.pdf_btn prm-icon{ - min-width: 22px; - min-height: 22px; - width: 20px; - height: 20px; - /*color: #ff2116;*/ -} -.pdf_btn { - margin-top: 15px; -} -.pdf_btn a{ - padding: 5px; - border: 2px rgb(40, 167, 69) solid; - background-color: rgba(40, 167, 69, .2); - border-radius: 4px; - color: rgb(58, 58, 58); -} -.pdf_btn:hover a{ - background-color: rgba(40, 167, 69, .4); - border-radius: 4px; - color: black; -} - -/* Lien vers les séries */ -.link_gray{ - color: gray !important; -} - -/* Icône du lien direct vers les ebooks */ - -prm-search-result-availability-line-after prm-icon{color: rgba(58,58,58,.4) !important;} -prm-search-result-availability-line-after md-icon{ - height: 15px; - width: 15px; - min-height: 15px; - min-width: 15px; - margin-right: .35em; -} - -/* Couleur de texte disponible liste recherche */ -prm-search-result-availability-line .availability-status.available_in_library, prm-search-result-availability-line .availability-status.not_restricted { - color:rgb(15, 125, 0)!important; -} - -/* Mise en évidence des boutons pour les demandes de service */ -/* span[translate="AlmaRequest"] { - text-decoration: underline #0B0 3px; - padding: 2px 6px; -} -span[translate="AlmaRequest"]:hover{ - background-color: #050 !important; - text-decoration: none; - color: white; - border-radius: 2px; -} */ -/* span[translate="nui.request.request"]{ - display: none; -} */ - -/* Soulignement des boutons proposant un service */ -prm-service-button button, .greenbutton { - padding-left: 0px !important; - padding-right: 0px !important; -} -prm-service-button button > span, .greenbutton>span { - background-color: #080 !important; - color: white !important; - padding: 2px 6px; - border-radius: 2px; -} -prm-service-button button > span:hover, .greenbutton>span:hover { - background-color: #050 !important; -} -prm-location-items > md-list > md-list-item > div > div > div > div > prm-service-button > button { - box-shadow: unset !important; -} -/* Alignement de l'intitulé "Demandes" */ -prm-request-services h3.section-title{ - top: 0px; -} - -/* Alignement central des boutons de demande */ -prm-request-services .labeled-block { - align-items: center; -} - -/* Suppression du sous-titre demande -span[translate="nui.request.request"]{ - display: none; -}*/ - -/* Suppression du bouton PEB -span[translate="AlmaResourceSharing"]{ - display: none; -} -.links-block .separated-block-item::after{ - content: none !important; -} */ - -/* Crée la place pour le titre et le sous-titre */ -prm-topbar { - height: 150px !important; -} -prm-main-menu[menu-type="menu"], -.top-nav-bar, -prm-search-bookmark-filter -{ - max-height: 60px !important; - height: 60px !important; - min-height: auto !important; -} - -/* Mise en forme du titre et sous-titre */ -.main-title{ - padding: .85em; - background-color: white; -} -.main-title h1{ - font-size: 2em !important; - margin-bottom: 0; -} -.main-title h1 > a{ - color: black; -} -prm-main-menu[menu-type="menu"] #mainMenu>div, prm-main-menu[menu-type="menu"] #mainMenu>button { - border-bottom: solid #ddd 1px; -} -.main-title h2{ - font-size: 1.2em !important; - font-weight: bold; -} - -/* Adapte le sous-titre lorsque l'écran est relativement petit */ -@media only screen and (max-width: 660px){ - .main-title h2{ - font-size: 1.1em !important; - } -} - -/* Menu sur les petits écrans */ -prm-main-menu[menu-type="full"] .md-button .md-headline{ - color: #ff9999 !important; -} -prm-main-menu .md-subhead{ - display: none; -} -.__sm prm-main-menu[menu-type="full"] .settings-container + md-divider{ - margin-top: 6em !important; -} - -/* Menu sur grand écran */ -prm-main-menu[menu-type="menu"] .button-over-dark, prm-topbar .md-button:not(.disable-hover){ - color: #222 !important; -} - -/* Petit triangle du menu */ -prm-user-area-expandable .button-with-menu-arrow:hover .menu-arrow:hover:not([disabled]){ - background-color: inherit; -} - -prm-databases-categorize button.is-selected{ - color: red !important; -} -prm-databases-categorize button:hover{ - background-color: #aaa !important; - color: inherit !important; -} -prm-databases-categorize button.is-selected:hover{ - color: red !important; -} -prm-tree-nav md-list md-list-item::after{ - opacity: 1 !important; -} -prm-tree-nav md-list md-list-item::after{ - opacity: .3 !important; -} -prm-databases-categorize h2, -prm-databases-categorize prm-tree-nav{ - width: 220px; - max-width: 220px; -} - -@media only screen and (max-width: 1100px){ - prm-databases-categorize h2, - prm-databases-categorize prm-tree-nav{ - width: 180px !important; - max-width: 180px !important; - } -} - -/* Concerne le module SLSP affichant le menu des langues. - -Supprimer l'allemand et l'italien dans les langues proposées */ - -bcu-lang-switch-component button:first-child, -bcu-lang-switch-component button:nth-child(3){ - display: None; -} diff --git a/primo-explore/custom/src/js/custom.js b/primo-explore/custom/src/js/custom.js deleted file mode 100644 index 037755b..0000000 --- a/primo-explore/custom/src/js/custom.js +++ /dev/null @@ -1,2 +0,0 @@ -!function n(i,l,o){function s(t,e){if(!l[t]){if(!i[t]){var r="function"==typeof require&&require;if(!e&&r)return r(t,!0);if(a)return a(t,!0);throw(r=new Error("Cannot find module '"+t+"'")).code="MODULE_NOT_FOUND",r}r=l[t]={exports:{}},i[t][0].call(r.exports,function(e){return s(i[t][1][e]||e)},r,r.exports,n,i,l,o)}return l[t].exports}for(var a="function"==typeof require&&require,e=0;e\n \n '}},{}],2:[function(e,t,r){"use strict";t.exports={bindings:{afterCtrl:"<"},controller:e("./collection_link.controller.js"),template:'
\r\n {{ \'seriesLink\' | customTranslate }} {{$ctrl.collection_title}}
\r\n
\r\n'}},{"./collection_link.controller.js":3}],3:[function(e,t,r){"use strict";t.exports=["$filter","$http",function(e,t){this.parentCtrl=this.afterCtrl.parentCtrl;var a=this;a.get_collection_url=function(){if(a.hasOwnProperty("collection_url"))return a.collection_url;try{var e=a.parentCtrl.result.pnx.display.series;if(!Array.isArray(e))throw new Error("Notice without series")}catch(e){return null}var t=!0,r=!1,n=void 0;try{for(var i,l=e[Symbol.iterator]();!(t=(i=l.next()).done);t=!0){var o,s=i.value.match(/\$\$Q(.*)\$\$Z(99\d{16})/);if(s)return o=a.parentCtrl.$stateParams.lang?"&lang="+a.parentCtrl.$stateParams.lang:"",a.collection_title=s[1],a.collection_url=window.location.origin+"/discovery/fulldisplay?vid="+a.parentCtrl.$stateParams.vid+"&tab="+a.parentCtrl.$stateParams.tab+"&docid=alma"+s[2]+"&context="+a.parentCtrl.$stateParams.context+o,a.collection_url}}catch(e){r=!0,n=e}finally{try{!t&&l.return&&l.return()}finally{if(r)throw n}}}}]},{}],4:[function(e,t,r){"use strict";var n=angular.module("briefviewModule",["angularLoad"]);n.component("slspSearchResultAvailabilityLineAfter",e("./availabilityline.component.js")),n.component("prmPdfArticleLink",e("./pdf_article_link.component.js")),n.component("prmPublisherLink",e("./publisher_link.component.js")),n.component("prmCollectionLink",e("./collection_link.component.js"))},{"./availabilityline.component.js":1,"./collection_link.component.js":2,"./pdf_article_link.component.js":5,"./publisher_link.component.js":7}],5:[function(e,t,r){"use strict";t.exports={bindings:{afterCtrl:"<"},controller:e("./pdf_article_link.controller.js"),template:'
\r\n {{ \'pdfAccess\' | customTranslate }}\r\n
\r\n'}},{"./pdf_article_link.controller.js":6}],6:[function(e,t,r){"use strict";t.exports=["$filter","$http","checkEpflIPFactory",function(e,t,r){this.parentCtrl=this.afterCtrl.parentCtrl;var s=this;function a(e){e=e.match(/10\.\d{4,9}\/[-._;()/:A-Z0-9]+/i);if(e)return e[0]}s.is_epfl_IP=r.is_epfl_ip(),s.get_doi=function(){if(s.parentCtrl.hasOwnProperty("result")&&s.parentCtrl.result.hasOwnProperty("pnx")){var e=s.parentCtrl.result.pnx;if("addata"in e&&"doi"in e.addata&&a(e.addata.doi[0])&&e.control.hasOwnProperty("recordtype")&&"article"===e.control.recordtype[0])return a(e.addata.doi[0]);if("display"in e&&"identifier"in e.display){var t=!0,r=!1,n=void 0;try{for(var i,l=e.display.identifier[Symbol.iterator]();!(t=(i=l.next()).done);t=!0){var o=i.value;if(a(o))return a(o)}}catch(e){r=!0,n=e}finally{try{!t&&l.return&&l.return()}finally{if(r)throw n}}}}},s.check_doi=function(){return s.hasOwnProperty("doi")||s.parentCtrl.hasOwnProperty("result")&&s.parentCtrl.result.hasOwnProperty("pnx")&&(s.get_doi()?(s.doi=s.get_doi(),s.set_url_pdf()):s.doi=null),!!s.hasOwnProperty("pdf_link")},s.set_url_pdf=function(){var e="https://public-api.thirdiron.com/public/v1/libraries/183/articles/doi/"+s.doi+"?access_token=adc54dee-c6a6-4b99-a917-2ed400f1f2d3";t({method:"GET",url:e}).then(function(e){if(200===e.status){try{var t=e.data.data.fullTextFile}catch(e){t=""}0\r\n
\r\n\r\n'}},{"./publisher_link.controller.js":8}],8:[function(e,t,r){"use strict";var n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e};t.exports=["$filter","$http","checkEpflIPFactory","$element",function(e,r,t,s){this.parentCtrl=this.afterCtrl.parentCtrl;var a=this;a.is_link_to_suppress=!1,a.$doCheck=function(){a.is_link_to_suppress&&a.suppress_original_link()},a.is_epfl_IP=t.is_epfl_ip(),a.is_pc=function(){return"PC"===a.parentCtrl.result.context},a.is_ebook=function(){return a.parentCtrl.result.pnx.control.hasOwnProperty("recordtype")?-1!==a.parentCtrl.result.pnx.control.recordtype[0].indexOf("book"):!!a.parentCtrl.result.pnx.display.hasOwnProperty("type")&&-1!==a.parentCtrl.result.pnx.display.type[0].toLowerCase().indexOf("book")},a.is_article=function(){return!!a.parentCtrl.result.pnx.control.hasOwnProperty("recordtype")&&-1!==a.parentCtrl.result.pnx.control.recordtype[0].indexOf("article")},a.is_data_available=function(){return a.parentCtrl.result&&a.parentCtrl.result.pnx&&a.parentCtrl.result.delivery},a.is_fulltext=function(){var e=a.parentCtrl.result.delivery.availability;return-1!==e.indexOf("fulltext")||-1!==e.indexOf("not_restricted")},a.suppress_original_link=function(){var e=s[0].parentElement.parentElement.parentElement.querySelectorAll(".not_restricted,.fulltext"),t=a.is_link_to_suppress=!0,r=!1,n=void 0;try{for(var i,l=e[Symbol.iterator]();!(t=(i=l.next()).done);t=!0){var o=i.value;o.classList.contains("no-delete")||(o.parentElement.parentElement.parentElement.remove(),a.is_link_to_suppress=!1);break}}catch(e){r=!0,n=e}finally{try{!t&&l.return&&l.return()}finally{if(r)throw n}}},a.is_publisher_url=function(){var e,t;return!a.checked&&a.is_data_available()&&a.is_epfl_IP&&(a.is_ebook()||a.is_article())&&(!a.parentCtrl.isFullView&&a.is_fulltext()&&a.is_pc()?(a.checked=!0,e=window.location.origin+"/primaws/rest/pub/pcDelivery/"+a.parentCtrl.result.pnx.control.recordid[0]+"?vid="+a.parentCtrl.$stateParams.vid,r.post(e,{doc:a.parentCtrl.result}).then(function(e){a.publisher_url=e.data.delivery.electronicServices[0].serviceUrl,a.suppress_original_link()})):a.parentCtrl.isFullView||!a.is_fulltext()||a.is_pc()?a.parentCtrl.isFullView&&a.parentCtrl.result.delivery.GetIt1&&"object"===n(a.parentCtrl.result.delivery.GetIt1)?(a.checked=!0,-1!==(t=a.parentCtrl.result.delivery.availability.indexOf("not_restricted"))&&(a.publisher_url=a.parentCtrl.result.delivery.GetIt1[0].links[t].link,a.suppress_original_link())):a.is_fulltext()||(a.checked=!0):(a.checked=!0,t=window.location.origin+"/primaws/rest/pub/edelivery/"+a.parentCtrl.result.pnx.control.recordid[0]+"?vid="+a.parentCtrl.$stateParams.vid,r.post(t,{doc:a.parentCtrl.result}).then(function(e){a.publisher_url=e.data.electronicServices[0].serviceUrl,a.suppress_original_link()}))),a.hasOwnProperty("publisher_url")}}]},{}],9:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});r.checkEpflIPFactory=angular.module("checkEpflIPModule",[]).factory("checkEpflIPFactory",["jwtHelper",function(t){function r(){var e=sessionStorage.getItem("primoExploreJwt");if(e)return t.decodeToken(e).userIp}return{is_epfl_ip:function(){var e=r();if(e){e=e.match(/128\.17([89])\.(\d{1,3})\./);if(e&&("8"==e[1]||128<=parseInt(e[2])))return!0}return!1},get_ip:r}}])},{}],10:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.factoryModule=void 0;e=e("./check_epfl_ip.factory");t.exports="factoryModule",(r.factoryModule=angular.module("factoryModule",[])).requires.push(e.checkEpflIPFactory.name)},{"./check_epfl_ip.factory":9}],11:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});r.customTranslateFilter=angular.module("customTranslateFilter",[]).filter("customTranslate",["$translate",function(r){return function(e){var t={contactEpflLibrary:{fr:"https://www.epfl.ch/campus/library/fr/informations-pratiques/#contact",en:"https://www.epfl.ch/campus/library/practical-information/#contact"},costWarningScan:{fr:'Service payant: les collaborateurs et les étudiants de l’EPFL peuvent bénéficier de ce service gratuitement, en utilisant le formulaire:',en:'Fee-based service: EPFL employees and students can benefit from this service free of charge by using the form:',de:'Kostenpflichtiger Service: Mitarbeitern und Studenten der EPFL steht dieser Dienst über das Fernleihe-Formular gratis zur Verfügung.',it:'Servizio a pagamento: I dipendenti e gli studenti dell\'EPFL possono usufruire gratuitamente di questo servizio utilizzando il modulo:'},costWarningScanEPFL:{fr:"Service gratuit pour les collaborateurs et les étudiants EPFL.",en:"Free of charge for EPFL staff and students.",de:"Service für Mitarbeiter und Studenten der EPFL kostenlos",it:"Servizio gratuito per i dipendenti e gli studenti dell’EPFL."},costWarningNetworkLoan:{fr:"Service gratuit en cas de retrait à la Bibliothèque de l’EPFL.",en:"Free of charge if withdrawal at the EPFL Library.",de:"Service bei Abholung in der EPFL-Bibliothek kostenlos.",it:"Servizio gratuito in caso di ritiro alla Biblioteca dell’EPFL"},costWarningPEB:{fr:"Service gratuit pour les collaborateurs et les étudiants de l’EPFL. Avant de passer une commande d’un document physique via le prêt entre bibliothèques, merci de vous assurer que ce document n'est pas disponible dans d’autres bibliothèques du réseau SLSP dans swisscovery.",en:"Free of charge for EPFL staff and students. Before placing an order for a physical document via the interlibrary loan, please make sure that this document is not available in other SLSP network libraries on swisscovery.",de:"Kostenloser Service für Mitarbeiter und Studenten der EPFL. Bevor Sie ein Medium über die Fernleihe bestellen, vergewissern Sie sich bitte zunächst in swisscovery, dass es nicht in einer anderen Bibliothek des SLSP-Netzwerks verfügbar ist.",it:"Servizio gratuito per i dipendenti e gli studenti dell’EPFL. Prima di ordinare un documento cartaceo tramite il prestito interbibliotecario, assicuratevi che questo documento non sia disponibile in altre biblioteche della rete SLSP in swisscovery."},mainTitle:{fr:"Catalogue BEAST",en:"BEAST discovery tool",de:"BEAST Wissensportal",it:"Catalogo BEAST"},subTitle:{fr:"Le point d'accès à toutes les ressources de la Bibliothèque de l'EPFL",en:"The access portal to all the resources of the EPFL Library",de:"Der Zugangspunkt zu allen Ressourcen der EPFL Bibliothek",it:"Il punto d’accesso a tutte le risorse della Biblioteca dell’EPFL"},switchEduID:{fr:"Modifier vos informations personnelles sur",en:"Change your personal data on",de:"Ändern Sie Ihre persönlichen Daten auf",it:"Modifica i tuoi dati personali sul"},illButton:{fr:"Prêt entre bibliothèques (PEB)",en:"Inter Library Loan (ILL)",de:"Fernleihe",it:"Prestito interbibliotecario"},feedbackLink:{fr:"Signaler un problème d'accès",en:"Report an access problem",de:"Zugriffsproblem melden",it:"Segnalare un problema di accesso"},vpnMSG:{fr:'Les ressources électroniques sont accessibles depuis tous les postes de l’EPFL, et à distance via le VPN EPFL.',en:'Electronic resources are accessible from all EPFL workstations, and remotely via the EPFL VPN.',de:'Elektronische Informationsressourcen sind an allen EPFL-Arbeitsplätzen und per EPFL VPN abrufbar.',it:'Le risorse elettroniche sono accessibili da tutte le postazioni di lavoro dell\'EPFL e a distanza tramite VPN EPFL.'},feedbackLinkMSG:{fr:"I have a problem accessing the electronic resource below. Please let me know when the access will be restored.",en:"I have a problem accessing the electronic resource below. Please let me know when the access will be restored.",de:"I have a problem accessing the electronic resource below. Please let me know when the access will be restored.",it:"I have a problem accessing the electronic resource below. Please let me know when the access will be restored."},pdfAccess:{fr:"Accès direct au pdf",en:"Direct access to the pdf",de:"Direct access to the pdf",it:"Direct access to the pdf"},seriesLink:{fr:"Collection :",en:"Serie:",de:"Serie:",it:"Serie:"}};return["en","fr","it","de"].includes(r.use())?t[e][r.use()]:t[e].fr}}])},{}],12:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.filtersModule=void 0;e=e("./custom_translate.filter");(r.filtersModule=angular.module("filtersModule",[])).requires.push(e.customTranslateFilter.name)},{"./custom_translate.filter":11}],13:[function(e,t,r){"use strict";t.exports={bindings:{parentCtrl:"<"},controller:e("./epfl-i-button.controller.js")}},{"./epfl-i-button.controller.js":14}],14:[function(e,t,r){"use strict";t.exports=["$element","$filter",function(r,n){var i=this;i.$doCheck=function(){var e,t;!i.checked&&i.parentCtrl.loc&&(t=r[0].parentElement.parentElement.getElementsByTagName("slsp-i-button-component")[0].getElementsByTagName("a")[0],"E02"===this.parentCtrl.loc.location.libraryCode&&t.setAttribute("href",n("customTranslate")("contactEpflLibrary")),"/discovery/custom/41SLSP_NETWORK-CENTRAL_PACKAGE/img/information.png"==(e=t.getElementsByTagName("img")[0]).getAttribute("src")&&(t=i.parentCtrl.configurationUtil.vid.replace(":","-"),e.setAttribute("src","custom/"+t+"/img/information.png"),e.setAttribute("width","22"),i.checked=!0))}}]},{}],15:[function(e,t,r){"use strict";t.exports={bindings:{parentCtrl:"<"},controller:e("./epfl_almaviewit.controller.js"),template:'\r\n\r\n\r\n'}},{"./epfl_almaviewit.controller.js":16}],16:[function(e,t,r){"use strict";t.exports=["$filter","checkEpflIPFactory",function(e,t){var r,n,i,l,o,s,a,c=this;c.get_txt=function(){return e("customTranslate")("vpnMSG")},c.feedbackLink="",c.is_epfl_IP=!1,c.no_report_link=!1,c.parentCtrl.item.pnx&&(c.parentCtrl.item.pnx.addata.openaccess&&"true"===c.parentCtrl.item.pnx.addata.openaccess[0]&&(c.no_report_link=!0),c.parentCtrl.item.pnx.addata.oa&&"free_for_read"===c.parentCtrl.item.pnx.addata.oa[0]&&(c.no_report_link=!0),c.no_report_link||(c.is_epfl_IP=t.is_epfl_ip(),c.user_ip=t.get_ip(),r=c.parentCtrl.item.pnx.control.recordid[0],n="",c.parentCtrl.item.pnx.display.title&&0ISBN")||-1ISSN")?s=c.parentCtrl.item.pnx.display.identifier.join(", ").replace(/<\/b>/g,"").replace(//g,""):-1'}},{}],19:[function(e,t,r){"use strict";t.exports={active:!1,txt:{fr:'
\n

Le réseau NEBIS a pris fin le 7 décembre 2020 pour être remplacé par un nouveau réseau plus vaste : swisscovery

\n
',en:'
\n

The NEBIS network ended on December 7, 2020. It has been replaced by swisscovery: a new and wider network.

\n
'},begin:"2020-01-04T00:00:00Z",end:"2023-03-31T12:00:00Z"}},{}],20:[function(e,t,r){"use strict";var n=angular.module("homepageModule",["angularLoad"]);n.component("prmSearchBarAfter",e("./searchbar.component.js")),n.component("prmMainMenuAfter",e("./mainmenu.component.js")),n.component("prmTopbarAfter",e("./topbar.component.js"))},{"./mainmenu.component.js":21,"./searchbar.component.js":22,"./topbar.component.js":23}],21:[function(e,t,r){"use strict";t.exports={bindings:{parentCtrl:"<"},controllerAs:"ctrl",controller:[function(){var t=this;this.$doCheck=function(){if(!t.modified&&"complete"===document.readyState){try{var e=document.querySelector("[translate='mainmenu.label.db']").parentElement}catch(e){t.modified=!1}e&&(e.removeAttribute("target"),e.setAttribute("aria-label","Databases"),t.modified=!0)}}}]}},{}],22:[function(n,e,t){"use strict";e.exports={bindings:{parentCtrl:"<"},template:'
',controllerAs:"ctrl",controller:["$translate",function(t){var e,r=this;r.alert=n("./alert_message.js"),!(r.active=!1)===r.alert.active&&(e=Date.now(),new Date(r.alert.begin)\n

{{ 'mainTitle' | customTranslate }}

\n

{{ 'subTitle' | customTranslate }}

\n "}},{}],24:[function(e,t,r){"use strict";e("./briefview"),e("./homepage"),e("./fullView"),e("./filters"),e("./factory"),e("./slsp_mod_epfl"),e("./slsp/slsp-ill-signin-order-alert"),e("./slsp/prm-locations-after"),e("./slsp/prm-location-items-after"),e("./slsp/slsp-archives-htgi"),e("./slsp/slsp-archives-viewit"),e("./slsp/slsp-http-intercept-requests"),e("./slsp/prm-user-area-expandable-after"),e("./slsp/prm-loan-after"),e("./slsp/prm-personal-info-after");angular.module("viewCustom",[].concat(["angularLoad"],["briefviewModule","homepageModule","fullviewModule","filtersModule","factoryModule","epflCourierInfoModule"],["slspIllSigninOrderAlert","ethLocationsAfterModule","ethLocationItemsAfterModule","slspArchivesHtgi","slspArchivesViewit","slspHttpInterceptRequests","slspUserAreaExpandableAfterModule","slspLoanAfterModule","slspPersonalInfoAfterModule"]))},{"./briefview":4,"./factory":10,"./filters":12,"./fullView":17,"./homepage":20,"./slsp/prm-loan-after":25,"./slsp/prm-location-items-after":28,"./slsp/prm-locations-after":33,"./slsp/prm-personal-info-after":38,"./slsp/prm-user-area-expandable-after":44,"./slsp/slsp-archives-htgi":45,"./slsp/slsp-archives-viewit":47,"./slsp/slsp-http-intercept-requests":49,"./slsp/slsp-ill-signin-order-alert":51,"./slsp_mod_epfl":54}],25:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.slspLoanAfterModule=void 0;e=e("./slsp-renew-item-text/slsp-renew-item-text.module");(r.slspLoanAfterModule=angular.module("slspLoanAfterModule",[]).component("prmLoanAfter",{bindings:{parentCtrl:"<"},template:''})).requires.push(e.slspRenewItemTextModule.name)},{"./slsp-renew-item-text/slsp-renew-item-text.module":27}],26:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=function(e,t,r){return t&&i(e.prototype,t),r&&i(e,r),e};function i(e,t){for(var r=0;r\r\n \r\n\r\n
\r\n {{$ctrl.getRenewText()}}\r\n\r\n
\r\n'})},{"./slsp-renew-item-text.controller":26}],28:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.ethLocationItemsAfterModule=void 0;var n=e("./eth-location-items-filter/eth-location-items-filter.module"),e=e("./slsp-i-button/slsp-i-button.module"),r=r.ethLocationItemsAfterModule=angular.module("ethLocationItemsAfterModule",[]).component("prmLocationItemsAfter",{bindings:{parentCtrl:"<"},template:''});r.requires.push(n.ethLocationItemsFilterModule.name),r.requires.push(e.slspIButtonModule.name)},{"./eth-location-items-filter/eth-location-items-filter.module":30,"./slsp-i-button/slsp-i-button.module":32}],29:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=function(e,t,r){return t&&i(e.prototype,t),r&&i(e,r),e};function i(e,t){for(var r=0;r\r\n \r\n \r\n {{ $ctrl.getLibrary() }}\r\n \r\n'})},{"./slsp-i-button.controller":31}],33:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.ethLocationsAfterModule=void 0;e=e("./eth-locations-filter/eth-locations-filter.module");(r.ethLocationsAfterModule=angular.module("ethLocationsAfterModule",[]).component("prmLocationsAfter",{bindings:{parentCtrl:"<"},template:''})).requires.push(e.ethLocationsFilterModule.name)},{"./eth-locations-filter/eth-locations-filter.module":35}],34:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=function(e,t,r){return t&&i(e.prototype,t),r&&i(e,r),e};function i(e,t){for(var r=0;r div.layout-wrap.layout-align-center-start.layout-row > md-card:nth-child(2)")),t=angular.element(document.querySelector("#SLSPeditPersonalDetails"));e.append(t)}}catch(e){console.error("***SLSP*** an error occured: EditPersonalDetailsController\n\n"),console.error(e.message)}}}]),l)).$inject=["$scope"]},{}],37:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.slspEditPersonalDetailsModule=void 0;e=e("./slsp-edit-personal-details.controller");r.slspEditPersonalDetailsModule=angular.module("slspEditPersonalDetailsModule",[]).controller("slspEditPersonalDetailsController",e.slspEditPersonalDetailsController).component("slspEditPersonalDetailsComponent",{bindings:{afterCtrl:"<"},controller:"slspEditPersonalDetailsController",template:'{{ $ctrl.buttonMove() }}\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'})},{"./slsp-edit-personal-details.controller":36}],38:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0}),r.slspPersonalInfoAfterModule=void 0;e=e("./slsp-edit-personal-details/slsp-edit-personal-details.module");(r.slspPersonalInfoAfterModule=angular.module("slspPersonalInfoAfterModule",[]).component("prmPersonalInfoAfter",{bindings:{parentCtrl:"<"},template:''})).requires.push(e.slspEditPersonalDetailsModule.name)},{"./slsp-edit-personal-details/slsp-edit-personal-details.module":37}],39:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=function(e,t,r){return t&&i(e.prototype,t),r&&i(e,r),e};function i(e,t){for(var r=0;r{{lang}}'})},{"./bcu-lang-switch.controller":39}],41:[function(e,t,r){"use strict";Object.defineProperty(r,"__esModule",{value:!0});var n=function(e,t,r){return t&&i(e.prototype,t),r&&i(e,r),e};function i(e,t){for(var r=0;r'});r.requires.push(n.bcuLangSwitchModule.name),r.requires.push(e.slspIllSigninOrderLoggedOutModule.name)},{"./bcu-lang-switch/bcu-lang-switch.module":40,"./slsp-ill-signin-order-logged-out/slsp-ill-signin-order-logged-out.module":42}],45:[function(e,t,r){"use strict";e("./js/slsp-archives-htgi.module.js"),t.exports="slspArchivesHtgi"},{"./js/slsp-archives-htgi.module.js":46}],46:[function(e,t,r){"use strict";angular.module("slspArchivesHtgi",[]).controller("ArchivesHtgiController",[function(){this.$onInit=function(){try{if(!this.parentCtrl.item.pnx.display.source||0===this.parentCtrl.item.pnx.display.source.length)return;var e,t;this.source=this.parentCtrl.item.pnx.display.source[0],"ETH_MaxFrischArchiv"!==this.source&&"ETH_ThomasMannArchiv"!==this.source||(document.getElementById("full-view-container").classList.add("slsp-archives-hide"),t=(e=this.parentCtrl.item.pnx.control.originalsourceid[0]).substring(e.lastIndexOf(":")+1),"ETH_ThomasMannArchiv"===this.source?this.url="http://www.online.tma.ethz.ch/home/#/content/"+t:"ETH_MaxFrischArchiv"===this.source&&(this.url="http://maxfrischarchiv-online.ethz.ch/home/#/content/"+t))}catch(e){console.error("***SLSP*** an error occured: ArchivesHtgiController\n\n"),console.error(e.message)}}}]).component("almaHtgiSvcAfter",{bindings:{parentCtrl:"<"},controller:"ArchivesHtgiController",template:'\n
\n \n \n {{(\'customized.archives.\' + $ctrl.source + \'.linktext\' | translate)}}\n {{$ctrl.label}}\n
\n \n
\n
\n
\n
\n
\n No request possible. The digitized item can be consulted in the Thomas Mann Archives reading room upon advance registration (\n \n Contact\n \n \n ).\n
\n
\n
\n
\n Informationen zu Bestellung und Benutzung siehe\n \n Bedienungshinweise\n \n \n .\n
\n
\n
\n '})},{}],47:[function(e,t,r){"use strict";e("./js/slsp-archives-viewit.module.js"),t.exports="slspArchivesViewit"},{"./js/slsp-archives-viewit.module.js":48}],48:[function(e,t,r){"use strict";angular.module("slspArchivesViewit",[]).component("prmSearchResultAvailabilityLineAfter",{bindings:{parentCtrl:"<"},controller:"ArchivesAvailabilityLineController",template:''}).component("prmAlmaViewitAfter",{bindings:{parentCtrl:"<"},controller:"ArchivesViewitController",template:'\n
\n \n \n {{(\'customized.archives.\' + $ctrl.source + \'.linktext\' | translate)}}\n {{$ctrl.label}}\n
\n \n
\n
\n
\n
\n
\n Informationen zu Bestellung und Benutzung siehe\n \n Bedienungshinweise\n \n \n .\n
\n
\n
\n '}).controller("ArchivesViewitController",["$translate",function(r){this.$onInit=function(){try{if(!this.parentCtrl.item.pnx.display.source||0===this.parentCtrl.item.pnx.display.source.length)return;if(this.source=this.parentCtrl.item.pnx.display.source[0],"ETH_Hochschularchiv"===this.source){if(this.parentCtrl.item.delivery.GetIt1&&0{{$ctrl.getAlert()}}'})},{}],53:[function(e,t,r){"use strict";angular.module("epflCourierInfoModule",[]).controller("CourierInfoController",["$filter","$element",function(i,e,t,r,n){var l=this;l.form=e[0].parentElement,l.$doCheck=function(){var e,t,r=!1,n=2;void 0===l.form.children[0].children[1]||void 0===l.form.children[0].children[1].children[0]&&"costWarningPEB"!=l.typeFeeAlert()?void 0!==l.form.children[0].children[0]&&void 0!==l.form.children[0].children[0].children[0]&&(r=l.form.children[0].children[0].children[0],n=3):(r=l.form.children[0].children[1].children[0],"costWarningPEB"==l.typeFeeAlert()&&(n=3)),(r&&r.children.length==n&&1

'+l.getFeeAlert()+"

","costWarningScan"==l.typeFeeAlert()&&(e=i("customTranslate")("illButton"),t+='

'+e+"

"),t+='

'+l.parentCtrl.$translate.instant("customize.fullview.feesLinkText")+"

",t=angular.element(t)[0],r.children.length==n?r.insertBefore(t,r.children[n-1]):r.children[r.children.length-2].replaceWith(t))},Object.defineProperty(l.parentCtrl,"form",{configurable:!0,get:function(){var e=this.getFilteredForm(["label","multiLabel"],!1);if(!l.hasOwnProperty("pickupLocationsListOrdered"))for(var t=0;t\r\n \r\n `\r\n}\r\n","\"use strict\";\r\n\r\n/*\r\n Ce module ajoute le lien vers la notice de collection sur les notices\r\n filles.\r\n */\r\n\r\nimport {collectionLinkHtml} from './collection_link.html';\r\n\r\nmodule.exports = {\r\n bindings: {afterCtrl: '<'},\r\n controller: require ('./collection_link.controller.js'),\r\n template: collectionLinkHtml,\r\n}\r\n","module.exports = ['$filter', '$http', function($filter, $http) {\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n var vm = this\r\n\r\n // Obtenir l'url d'une série.\r\n vm.get_collection_url = function(){\r\n\r\n // Vérifie si l'analyse a déjà été effectuée. Si oui, le lien est\r\n // directement retourné\r\n if (vm.hasOwnProperty('collection_url')){\r\n return vm.collection_url;\r\n }\r\n try {\r\n var series = vm.parentCtrl.result.pnx.display.series;\r\n if (!Array.isArray(series)) {throw new Error('Notice without series');}\r\n } catch (e) {\r\n // Pas de notice de série trouvée\r\n return null;\r\n }\r\n for (const serie of series){\r\n // On ne retient que les notices de séries dont l'identifiant\r\n // est un mms ID\r\n var m = serie.match(/\\$\\$Q(.*)\\$\\$Z(99\\d{16})/);\r\n\r\n if (m){\r\n // Un mms ID a été trouvé -> construction de l'url vers la notice.\r\n if (!vm.parentCtrl.$stateParams.lang) {\r\n var lang = '';\r\n } else {\r\n var lang = `&lang=${vm.parentCtrl.$stateParams.lang}`;\r\n }\r\n vm.collection_title = m[1];\r\n vm.collection_url = `${ window.location.origin }/discovery/fulldisplay?vid=${ vm.parentCtrl.$stateParams.vid }&tab=${ vm.parentCtrl.$stateParams.tab }&docid=alma${ m[2] }&context=${ vm.parentCtrl.$stateParams.context }${ lang }`;\r\n return vm.collection_url;\r\n }\r\n }\r\n }\r\n\r\n // console.log(vm);\r\n}]\r\n","/* Importe en tant que compasant l'ensemble des éléments personnalisés EPFL.\r\nCela comporte l'affichage des collections, les liens directs vers le pdf,\r\net le lien direct vers le site de l'éditeur.\r\n*/\r\nvar briefview_module = angular.module('briefviewModule', ['angularLoad']);\r\nbriefview_module.component('slspSearchResultAvailabilityLineAfter', require('./availabilityline.component.js'));\r\nbriefview_module.component('prmPdfArticleLink', require('./pdf_article_link.component.js'));\r\nbriefview_module.component('prmPublisherLink', require('./publisher_link.component.js'));\r\nbriefview_module.component('prmCollectionLink', require('./collection_link.component.js'));\r\n","\"use strict\";\r\n\r\n/*\r\n Ce module ajoute le lien direct vers le fichier pdf quand celui-ci\r\n est disponible via l'api de Browzine.\r\n */\r\n\r\n\r\nimport {pdfArticleLinkHtml} from './pdf_article_link.html';\r\n\r\nmodule.exports = {\r\n bindings: {afterCtrl: '<'},\r\n controller: require('./pdf_article_link.controller.js'),\r\n template: pdfArticleLinkHtml,\r\n}\r\n","module.exports = ['$filter', '$http', 'checkEpflIPFactory', function($filter, $http, checkEpflIPFactory) {\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n var vm = this\r\n\r\n // Extrait le DOI brut depuis une chaîne de caractères\r\n function parse_doi(txt){\r\n var re = /10\\.\\d{4,9}\\/[-._;()/:A-Z0-9]+/i;\r\n var m = txt.match(re);\r\n if (m){\r\n return m[0]\r\n }\r\n }\r\n\r\n /* Teste si l'utilisateur est sur le range EPFL afin de décider s'il faut\r\n faut ou non afficher le lien direct */\r\n vm.is_epfl_IP = checkEpflIPFactory.is_epfl_ip();\r\n\r\n // Retourne le doi de la ressource en vérifiant plusieurs emplacements\r\n // dans le pnx.\r\n vm.get_doi = function(){\r\n if (vm.parentCtrl.hasOwnProperty('result') && vm.parentCtrl.result.hasOwnProperty('pnx')){\r\n var pnx = vm.parentCtrl.result.pnx;\r\n\r\n // Recherche dans la section addata\r\n if ('addata' in pnx && 'doi' in pnx.addata && parse_doi(pnx.addata.doi[0]) && pnx.control.hasOwnProperty('recordtype') && pnx.control.recordtype[0]==='article') {\r\n return parse_doi(pnx.addata.doi[0])\r\n }\r\n\r\n // Recherche dans la section display\r\n if ('display' in pnx && 'identifier' in pnx.display) {\r\n for (const identifier of pnx.display.identifier){\r\n if (parse_doi(identifier)){\r\n return parse_doi(identifier)\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n // Vérifie si un doi est disponible. Dans le cas contraire\r\n vm.check_doi = function(){\r\n if (!vm.hasOwnProperty('doi')){\r\n if (vm.parentCtrl.hasOwnProperty('result') && vm.parentCtrl.result.hasOwnProperty('pnx')){\r\n if (vm.get_doi()){\r\n vm.doi = vm.get_doi();\r\n vm.set_url_pdf()\r\n\r\n } else {\r\n // Empêchera une nouvelle recherche via get_doi\r\n vm.doi = null;\r\n }\r\n }\r\n }\r\n if (vm.hasOwnProperty('pdf_link')) {\r\n return true\r\n }\r\n return false\r\n }\r\n\r\n // Fonction interrogeant l'api de Browzine pour obtenir le lien direct vers\r\n // le pdf.\r\n vm.set_url_pdf = function(){\r\n var url = `https://public-api.thirdiron.com/public/v1/libraries/183/articles/doi/${vm.doi}?access_token=adc54dee-c6a6-4b99-a917-2ed400f1f2d3`;\r\n $http({\r\n method: 'GET',\r\n url: url\r\n }).then(function successCallback(response) {\r\n // console.log(response);\r\n if (response.status === 200) {\r\n try{\r\n var pdf_link = response.data.data.fullTextFile;\r\n } catch(e){\r\n var pdf_link = '';\r\n }\r\n if (pdf_link.length > 0) {\r\n vm.pdf_link = pdf_link;\r\n }\r\n }\r\n // console.log(vm.pdf_link);\r\n }, function errorCallback(response) {\r\n vm.doi = null;\r\n });\r\n\r\n }\r\n // console.log(vm);\r\n}]\r\n","\"use strict\";\r\n\r\nimport {publisherLinkHtml} from './publisher_link.html';\r\n\r\nmodule.exports = {\r\n bindings: {afterCtrl: '<'},\r\n controller: require ('./publisher_link.controller.js'),\r\n template: publisherLinkHtml,\r\n}\r\n","module.exports = ['$filter', '$http', 'checkEpflIPFactory', '$element', function($filter, $http, checkEpflIPFactory, $element) {\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n var vm = this\r\n vm.is_link_to_suppress = false;\r\n\r\n // Fonction pour s'assurer que l'élément à supprimer le sera correctement\r\n vm.$doCheck = function(){\r\n if (vm.is_link_to_suppress){\r\n vm.suppress_original_link()\r\n }\r\n }\r\n\r\n // Utilise le service pour vérifier si l'utilisateur est sur le réseau EPFL\r\n vm.is_epfl_IP = checkEpflIPFactory.is_epfl_ip();\r\n\r\n // Vérifie si une ressource vient de CDI. L'attribut reste PC comme dans Primo Central l'ancien système.\r\n vm.is_pc = function(){\r\n return vm.parentCtrl.result.context === 'PC';\r\n }\r\n\r\n // Vérifie si le record est de type livre. Le lien direct vers l'éditeur est pertinent dans ce cas.\r\n vm.is_ebook = function(){\r\n if (vm.parentCtrl.result.pnx.control.hasOwnProperty('recordtype')){\r\n return vm.parentCtrl.result.pnx.control.recordtype[0].indexOf('book')!==-1;\r\n } else if (vm.parentCtrl.result.pnx.display.hasOwnProperty('type')){\r\n return vm.parentCtrl.result.pnx.display.type[0].toLowerCase().indexOf('book')!==-1;\r\n } else {\r\n return false;\r\n }\r\n }\r\n\r\n // Vérifie si la ressource est un article. Le lien direct vers l'éditeur est pertinent pour les articles.\r\n vm.is_article = function(){\r\n if (vm.parentCtrl.result.pnx.control.hasOwnProperty('recordtype')){\r\n return vm.parentCtrl.result.pnx.control.recordtype[0].indexOf('article')!==-1;\r\n } else {\r\n return false;\r\n }\r\n\r\n }\r\n\r\n // Vérifie si le PNX est chargé\r\n vm.is_data_available = function(){\r\n return vm.parentCtrl.result && vm.parentCtrl.result.pnx && vm.parentCtrl.result.delivery;\r\n }\r\n\r\n // Vérifie si un accès fulltext est disponible\r\n vm.is_fulltext = function(){\r\n let availability = vm.parentCtrl.result.delivery.availability\r\n return availability.indexOf('fulltext')!==-1 || availability.indexOf('not_restricted')!==-1;\r\n }\r\n\r\n // Supprime le lien original\r\n vm.suppress_original_link = function(){\r\n var aval_lines = $element[0].parentElement.parentElement.parentElement.querySelectorAll('.not_restricted,.fulltext');\r\n\r\n // Tant que cet attribut est vrai, la fonction $doCheck va tenter de supprimer le lien\r\n vm.is_link_to_suppress = true;\r\n\r\n // console.log($element[0]);\r\n // console.log(aval_lines);\r\n for (var aval_line of aval_lines){\r\n if (!aval_line.classList.contains('no-delete')){\r\n aval_line.parentElement.parentElement.parentElement.remove();\r\n vm.is_link_to_suppress = false}\r\n break;\r\n }\r\n\r\n }\r\n\r\n /* Définit l'url de l'éditeur si celle-ci est disponible à la place de\r\n l'affichage de la notice détaillée.\r\n La fonction retourne true si l'url est modifiée */\r\n vm.is_publisher_url = function(){\r\n /* L'url n'est modifié que pour les ebooks et les articles. De plus,\r\n il faut être dans le range IP de l'EPFL */\r\n if (!vm.checked && vm.is_data_available() && vm.is_epfl_IP && (vm.is_ebook() || vm.is_article())) {\r\n\r\n // L'adresse du service est différente selon que la ressource est dans cdi ou non (vm.is_pc())\r\n if (!vm.parentCtrl.isFullView && vm.is_fulltext() && vm.is_pc()){\r\n // Ressource CDI\r\n vm.checked = true;\r\n /* Les données ne contiennent pas des informations détaillées avec le lien direct.\r\n Il faut donc utiliser un service pour obtenir ces données. */\r\n let url = `${ window.location.origin }/primaws/rest/pub/pcDelivery/${vm.parentCtrl.result.pnx.control.recordid[0]}?vid=${vm.parentCtrl.$stateParams.vid}`;\r\n $http.post(url, {doc:vm.parentCtrl.result}).then((e) => {\r\n vm.publisher_url = e.data.delivery.electronicServices[0].serviceUrl;\r\n vm.suppress_original_link();\r\n });\r\n } else if (!vm.parentCtrl.isFullView && vm.is_fulltext() && !vm.is_pc()){\r\n // Ressource non CDI\r\n vm.checked = true;\r\n let url = `${ window.location.origin }/primaws/rest/pub/edelivery/${vm.parentCtrl.result.pnx.control.recordid[0]}?vid=${vm.parentCtrl.$stateParams.vid}`;\r\n $http.post(url, {doc:vm.parentCtrl.result}).then((e) => {\r\n vm.publisher_url = e.data.electronicServices[0].serviceUrl;\r\n vm.suppress_original_link();\r\n })\r\n\r\n } else if (vm.parentCtrl.isFullView && vm.parentCtrl.result.delivery.GetIt1 && typeof(vm.parentCtrl.result.delivery.GetIt1)==='object') {\r\n // Dans la vue détaillée, l'url est accessible sans avoir à interroger le service\r\n vm.checked = true;\r\n let rank = vm.parentCtrl.result.delivery.availability.indexOf('not_restricted');\r\n if (rank !== -1) {\r\n vm.publisher_url = vm.parentCtrl.result.delivery.GetIt1[0].links[rank].link;\r\n vm.suppress_original_link();\r\n }\r\n } else if (!vm.is_fulltext()){\r\n vm.checked = true;\r\n }\r\n }\r\n return vm.hasOwnProperty('publisher_url');\r\n }\r\n // console.log('Publisher_link:');\r\n // console.log(vm);\r\n // console.log('---------------');\r\n}]\r\n","/*\r\n DESCRIPTION:\r\n Permet de vérifier si l'utilisateur est connecté sur la plage\r\n réseau de l'EPFL.\r\n\r\n Le réseau EPFL doit commencer par 128.178 ou 128.179\r\n Pour 128.178, la plage ne commence qu'à 128.178.129\r\n\r\n Le service s'utilise de la manière suivante:\r\n module.exports = ['$filter', 'checkEpflIPFactory', function($filter, checkEpflIPFactory) {\r\n vm.is_epfl_IP = checkEpflIPFactory.is_epfl_ip();}]\r\n*/\r\n\r\n// EPFL : Fonctions de vérification des types utilisateurs\r\nexport const checkEpflIPFactory = angular\r\n .module('checkEpflIPModule', [])\r\n .factory('checkEpflIPFactory', ['jwtHelper', function( jwtHelper ){\r\n\r\n const is_epfl_ip = function () {\r\n const userIP = get_ip()\r\n if (userIP) {\r\n const regex = /128\\.17([89])\\.(\\d{1,3})\\./;\r\n const found = userIP.match(regex);\r\n if (found && (found[1] == '8' || parseInt(found[2])>=128)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n const get_ip = function(){\r\n var jwt = sessionStorage.getItem('primoExploreJwt');\r\n if (!jwt) {\r\n return;\r\n }\r\n return jwtHelper.decodeToken(jwt).userIp;\r\n }\r\n\r\n return {'is_epfl_ip': is_epfl_ip,\r\n 'get_ip': get_ip};\r\n }]);\r\n","module.exports = 'factoryModule'\r\n\r\nimport {checkEpflIPFactory} from './check_epfl_ip.factory';\r\n\r\nexport const factoryModule = angular\r\n .module('factoryModule', [])\r\n\r\nfactoryModule.requires.push(checkEpflIPFactory.name);\r\n","\"use strict\";\r\n\r\n/***********************/\r\n/* FILTRE : traduction */\r\n/***********************/\r\n\r\n/*\r\n OBJECTIF: traduire des éléments, tant des urls que du texte.\r\n UTILISATION:\r\n - Dans le template:\r\n 1. comme un filtre: {{ clé | customTranslate }}\r\n - Dans un controlleur:\r\n Même si les filtres sont d'abord prévus pour être utilisés dans le\r\n template, on peut les appeler dans les controlleurs.\r\n 1. Ajouter le service dans l'en-tête du controlleur\r\n 2. Appeler le service avec la fonction $filter\r\n EXEMPLE:\r\n controller:function($http, $filter){...\r\n var traduction = $filter('customTranslate')('cleTrad');\r\n ...}\r\n CONFIGURATION:\r\n L'ajout de traduction se fait à travers des objets. La clé indique le\r\n terme à utiliser dans le template ou le controlleur pour ensuite\r\n renvoyer la traduction. Les noms associés n'appaaraissent donc pas tels\r\n quels. La structure de chaque élément traduit disponible est comme suit:\r\n clé1:{\r\n fr: traductionFrançaise\r\n en: traductionAnglaise\r\n },\r\n clé2:{\r\n fr: traductionFrançaise\r\n en: traductionAnglaise\r\n }\r\n*/\r\nexport const customTranslateFilter = angular\r\n .module('customTranslateFilter', [])\r\n .filter('customTranslate', ['$translate', function($translate){\r\n return function(txt){\r\n var trad = {\r\n contactEpflLibrary:{\r\n fr: \"https://www.epfl.ch/campus/library/fr/informations-pratiques/#contact\",\r\n en: \"https://www.epfl.ch/campus/library/practical-information/#contact\"\r\n },\r\n costWarningScan:{\r\n fr: \"Service payant: les collaborateurs et les étudiants de l’EPFL peuvent bénéficier de ce service gratuitement, en utilisant le formulaire:\",\r\n en: \"Fee-based service: EPFL employees and students can benefit from this service free of charge by using the form:\",\r\n de: \"Kostenpflichtiger Service: Mitarbeitern und Studenten der EPFL steht dieser Dienst über das Fernleihe-Formular gratis zur Verfügung.\",\r\n it: \"Servizio a pagamento: I dipendenti e gli studenti dell'EPFL possono usufruire gratuitamente di questo servizio utilizzando il modulo:\"\r\n },\r\n costWarningScanEPFL:{\r\n fr: \"Service gratuit pour les collaborateurs et les étudiants EPFL.\",\r\n en: \"Free of charge for EPFL staff and students.\",\r\n de: \"Service für Mitarbeiter und Studenten der EPFL kostenlos\",\r\n it: \"Servizio gratuito per i dipendenti e gli studenti dell’EPFL.\"\r\n },\r\n costWarningNetworkLoan:{\r\n fr: \"Service gratuit en cas de retrait à la Bibliothèque de l’EPFL.\",\r\n en: \"Free of charge if withdrawal at the EPFL Library.\",\r\n de: \"Service bei Abholung in der EPFL-Bibliothek kostenlos.\",\r\n it: \"Servizio gratuito in caso di ritiro alla Biblioteca dell’EPFL\"\r\n },\r\n costWarningPEB:{\r\n fr: \"Service gratuit pour les collaborateurs et les étudiants de l’EPFL. Avant de passer une commande d’un document physique via le prêt entre bibliothèques, merci de vous assurer que ce document n'est pas disponible dans d’autres bibliothèques du réseau SLSP dans swisscovery.\",\r\n en: \"Free of charge for EPFL staff and students. Before placing an order for a physical document via the interlibrary loan, please make sure that this document is not available in other SLSP network libraries on swisscovery.\",\r\n de: \"Kostenloser Service für Mitarbeiter und Studenten der EPFL. Bevor Sie ein Medium über die Fernleihe bestellen, vergewissern Sie sich bitte zunächst in swisscovery, dass es nicht in einer anderen Bibliothek des SLSP-Netzwerks verfügbar ist.\",\r\n it: \"Servizio gratuito per i dipendenti e gli studenti dell’EPFL. Prima di ordinare un documento cartaceo tramite il prestito interbibliotecario, assicuratevi che questo documento non sia disponibile in altre biblioteche della rete SLSP in swisscovery.\"\r\n },\r\n mainTitle:{\r\n fr: \"Catalogue BEAST\",\r\n en: \"BEAST discovery tool\",\r\n de: \"BEAST Wissensportal\",\r\n it: \"Catalogo BEAST\"\r\n },\r\n subTitle:{\r\n fr: \"Le point d\\'accès à toutes les ressources de la Bibliothèque de l\\'EPFL\",\r\n en: \"The access portal to all the resources of the EPFL Library\",\r\n de: \"Der Zugangspunkt zu allen Ressourcen der EPFL Bibliothek\",\r\n it: \"Il punto d’accesso a tutte le risorse della Biblioteca dell’EPFL\"\r\n },\r\n switchEduID:{\r\n fr: \"Modifier vos informations personnelles sur\",\r\n en: \"Change your personal data on\",\r\n de: \"Ändern Sie Ihre persönlichen Daten auf\",\r\n it: \"Modifica i tuoi dati personali sul\"\r\n },\r\n illButton:{\r\n fr: \"Prêt entre bibliothèques (PEB)\",\r\n en: \"Inter Library Loan (ILL)\",\r\n de: \"Fernleihe\",\r\n it: \"Prestito interbibliotecario\"\r\n },\r\n feedbackLink:{\r\n fr: \"Signaler un problème d'accès\",\r\n en: \"Report an access problem\",\r\n de: \"Zugriffsproblem melden\",\r\n it: \"Segnalare un problema di accesso\"\r\n },\r\n vpnMSG:{\r\n fr: \"Les ressources électroniques sont accessibles depuis tous les postes de l’EPFL, et à distance via le VPN EPFL.\",\r\n en: \"Electronic resources are accessible from all EPFL workstations, and remotely via the EPFL VPN.\",\r\n de: \"Elektronische Informationsressourcen sind an allen EPFL-Arbeitsplätzen und per EPFL VPN abrufbar.\",\r\n it: \"Le risorse elettroniche sono accessibili da tutte le postazioni di lavoro dell'EPFL e a distanza tramite VPN EPFL.\"\r\n },\r\n // vpnLink:{\r\n // fr: \"https://www.epfl.ch/campus/services/ressources-informatiques/network-services-reseau/acces-intranet-a-distance/clients-vpn-disponibles/\",\r\n // en: \"https://www.epfl.ch/campus/services/en/it-services/network-services/remote-intranet-access/vpn-clients-available/\",\r\n // de: \"https://www.epfl.ch/campus/services/en/it-services/network-services/remote-intranet-access/vpn-clients-available/\",\r\n // it: \"https://www.epfl.ch/campus/services/en/it-services/network-services/remote-intranet-access/vpn-clients-available/\"\r\n // },\r\n feedbackLinkMSG:{\r\n fr: \"I have a problem accessing the electronic resource below. Please let me know when the access will be restored.\",\r\n en: \"I have a problem accessing the electronic resource below. Please let me know when the access will be restored.\",\r\n de: \"I have a problem accessing the electronic resource below. Please let me know when the access will be restored.\",\r\n it: \"I have a problem accessing the electronic resource below. Please let me know when the access will be restored.\"\r\n },\r\n pdfAccess:{\r\n fr: \"Accès direct au pdf\",\r\n en: \"Direct access to the pdf\",\r\n de: \"Direct access to the pdf\",\r\n it: \"Direct access to the pdf\"\r\n },\r\n seriesLink:{\r\n fr: \"Collection :\",\r\n en: \"Serie:\",\r\n de: \"Serie:\",\r\n it: \"Serie:\"\r\n }\r\n };\r\n if (['en', 'fr', 'it', 'de'].includes($translate.use())) {\r\n return trad[txt][$translate.use()]\r\n } else {\r\n return trad[txt].fr\r\n }\r\n };\r\n }]);\r\n","import {customTranslateFilter} from './custom_translate.filter';\r\n\r\nexport const filtersModule = angular\r\n .module('filtersModule', []);\r\n\r\nfiltersModule.requires.push(customTranslateFilter.name);\r\n","module.exports = {\r\n bindings: {parentCtrl: '<'},\r\n controller: require('./epfl-i-button.controller.js')}\r\n","module.exports = ['$element', '$filter', function($element, $filter) {\r\n var vm = this;\r\n vm.$doCheck = function() {\r\n if (!vm.checked && vm.parentCtrl.loc){\r\n // Lien du module SLSP\r\n var link = $element[0].parentElement.parentElement.getElementsByTagName('slsp-i-button-component')[0].getElementsByTagName('a')[0];\r\n if (this.parentCtrl.loc.location.libraryCode==='E02'){\r\n link.setAttribute('href', $filter('customTranslate')('contactEpflLibrary'))\r\n }\r\n\r\n // Récupère l'icone avec le i.\r\n var img = link.getElementsByTagName('img')[0];\r\n\r\n // Modification de l'image\r\n if (img.getAttribute('src')=='/discovery/custom/41SLSP_NETWORK-CENTRAL_PACKAGE/img/information.png') {\r\n const view = vm.parentCtrl.configurationUtil.vid.replace(':', '-');\r\n img.setAttribute('src', `custom/${ view }/img/information.png`);\r\n // Réduit la taille de l'image\r\n img.setAttribute('width', '22');\r\n\r\n // Evite de modifier plusieurs fois\r\n vm.checked = true;\r\n }\r\n }\r\n }\r\n // console.log(vm);\r\n}];\r\n","\"use strict\";\r\n\r\nimport {epfl_almaviewit_html} from './epfl_almaviewit.html'\r\n\r\n/*\r\n OBJECTIF: Ajouter un lien pour rapporter les problèmes d'accès aux\r\n ressources électroniques. Un message d'avertissement s'affiche quand la\r\n la personne n'est pas sur le réseau EPFL\r\n*/\r\n\r\nmodule.exports = {\r\n bindings: {parentCtrl: '<'},\r\n controller: require('./epfl_almaviewit.controller.js'),\r\n template: epfl_almaviewit_html}\r\n","\"use strict\";\r\n\r\n/*\r\n OBJECTIF: Ajouter un lien pour rapporter les problèmes d'accès aux\r\n ressources électroniques. Un message d'avertissement s'affiche quand la\r\n la personne n'est pas sur le réseau EPFL\r\n*/\r\n\r\nmodule.exports = ['$filter', 'checkEpflIPFactory', function($filter, checkEpflIPFactory) {\r\n var vm = this;\r\n\r\n vm.get_txt = function() {\r\n return $filter('customTranslate')('vpnMSG');\r\n }\r\n\r\n vm.feedbackLink = '';\r\n vm.is_epfl_IP = false;\r\n vm.no_report_link = false;\r\n\r\n if (vm.parentCtrl.item.pnx){\r\n\r\n // Ne pas afficher le lien s'il s'agit d'open access\r\n if (vm.parentCtrl.item.pnx.addata.openaccess && vm.parentCtrl.item.pnx.addata.openaccess[0] === 'true') {\r\n vm.no_report_link = true;\r\n }\r\n // Ne pas afficher le lien s'il s'agit d'open access (notices CDI)\r\n if (vm.parentCtrl.item.pnx.addata.oa && vm.parentCtrl.item.pnx.addata.oa[0] === 'free_for_read') {\r\n vm.no_report_link = true;\r\n }\r\n\r\n if (!vm.no_report_link){\r\n\r\n /* Obtient l'adresse ip depuis un service se trouvant dans le\r\n module \\js\\slsp\\slsp-ill-signin-order-logged-out\\js\\epfl-ill-signin-order-logged-out.module.js */\r\n vm.is_epfl_IP = checkEpflIPFactory.is_epfl_ip();\r\n vm.user_ip = checkEpflIPFactory.get_ip();\r\n\r\n // Récupération des métadonnées de la ressource\r\n var mmsId = vm.parentCtrl.item.pnx.control.recordid[0];\r\n var title = '';\r\n if (vm.parentCtrl.item.pnx.display.title && vm.parentCtrl.item.pnx.display.title.length > 0) {\r\n title = vm.parentCtrl.item.pnx.display.title[0];\r\n }\r\n var creationdate = '';\r\n if (vm.parentCtrl.item.pnx.display.creationdate && vm.parentCtrl.item.pnx.display.creationdate.length > 0) {\r\n creationdate = vm.parentCtrl.item.pnx.display.creationdate[0];\r\n }\r\n var creator = '';\r\n if (vm.parentCtrl.item.pnx.display.creator && vm.parentCtrl.item.pnx.display.creator.length > 0) {\r\n creator = vm.parentCtrl.item.pnx.display.creator.join(', ');\r\n }\r\n var type = '';\r\n if (vm.parentCtrl.item.pnx.display.type && vm.parentCtrl.item.pnx.display.type.length > 0) {\r\n type = vm.parentCtrl.item.pnx.display.type[0];\r\n }\r\n var identifier = '';\r\n if (vm.parentCtrl.item.pnx.display.identifier && vm.parentCtrl.item.pnx.display.identifier.length > 0) {\r\n var ident = vm.parentCtrl.item.pnx.display.identifier[0];\r\n if (ident.indexOf('ISBN') > -1) {\r\n identifier = vm.parentCtrl.item.pnx.display.identifier.join(', ').replace(/<\\/b>/g, '').replace(//g, '');\r\n } else if (ident.indexOf('ISSN') > -1) {\r\n identifier = vm.parentCtrl.item.pnx.display.identifier.join(', ').replace(/<\\/b>/g, '').replace(//g, '');\r\n } else if (ident.indexOf('ISBN') > -1) {\r\n identifier = 'ISBN: ' + ident.substring(ident.indexOf('$$V') + 3);\r\n } else if (ident.indexOf('ISSN') > -1) {\r\n identifier = 'ISSN: ' + ident.substring(ident.indexOf('$$V') + 3);\r\n }\r\n }\r\n var userAgent = navigator.userAgent;\r\n\r\n // Création de l'objet du message\r\n var subject = 'Access problem ' + mmsId + ' - \"' + title + '\"';\r\n\r\n // Création du corps du message\r\n var body = $filter('customTranslate')('feedbackLinkMSG') + '\\n\\n' + '****\\nTitle: ' + title + '\\nAuthor: ' + creator + '\\nYear: ' + creationdate + '\\nType: ' + type + '\\nDocId: ' + mmsId + '\\nIdentifier: ' + identifier + '\\nUser_agent: ' + userAgent + '\\nUserIP: ' + vm.user_ip + '\\nRange EPFL: ' + vm.is_epfl_IP + '\\n****';\r\n\r\n vm.feedbackLink = 'mailto:eresources@epfl.ch' + '?subject=' + encodeURIComponent(subject) + '&body=' + encodeURIComponent(body) + '&Content-Type=text/html';\r\n }\r\n }\r\n\r\n }]\r\n","\"use strict\";\r\n\r\n/*\r\n Ce module vient se greffer à la balise SLSP regroupe plusieurs modules en lien\r\n avec l'affichage détaillé:\r\n - Lien pour signaler les problèmes d'accès aux ressources électroniques\r\n */\r\n\r\nvar fullview_module = angular.module('fullviewModule', ['angularLoad']);\r\nfullview_module.component('slspAlmaViewitAfter', require('./epfl_almaviewit.component.js'));\r\nfullview_module.component('slspLocationItemsAfter', require('./slspLocationItemsAfter.component.js'));\r\nfullview_module.component('epflIButtonComponent', require('./epfl-i-button.component.js'));\r\n","\"use strict\";\r\n\r\nmodule.exports = {\r\n bindings: {parentCtrl: '<'},\r\n template: ``\r\n}\r\n","module.exports = {active: false,\r\n txt:\r\n {fr: `
\r\n

Le réseau NEBIS a pris fin le 7 décembre 2020 pour être remplacé par un nouveau réseau plus vaste : swisscovery

\r\n
`,\r\n en: `
\r\n

The NEBIS network ended on December 7, 2020. It has been replaced by swisscovery: a new and wider network.

\r\n
`},\r\n begin:\"2020-01-04T00:00:00Z\",\r\n end:\"2023-03-31T12:00:00Z\"}\r\n","var homepage_module = angular.module('homepageModule', ['angularLoad']);\r\nhomepage_module.component('prmSearchBarAfter', require('./searchbar.component.js'));\r\nhomepage_module.component('prmMainMenuAfter', require('./mainmenu.component.js'));\r\nhomepage_module.component('prmTopbarAfter', require('./topbar.component.js'));\r\n","/*\r\n DESCRIPTION:\r\n Corriger le lien du menu principal vers les bases de données.\r\n Empêche l'ouverture d'un nouvel onglet.\r\n*/\r\n\r\nmodule.exports = {\r\n bindings: {parentCtrl: '<'},\r\n controllerAs: 'ctrl',\r\n controller: [function() {\r\n var vm = this;\r\n\r\n // Effectue cette vérification lors de chaque digest.\r\n this.$doCheck = function() {\r\n\r\n // Vérifie si la page est chargée\r\n if (!vm.modified && document.readyState === 'complete'){\r\n\r\n // Essaie de trouver le menu des bases de données\r\n try{var elem = document.querySelector(\"[translate='mainmenu.label.db']\").parentElement;}\r\n catch(e){\r\n // L'élément n'est pas trouvé. Plus de nouvelles vérifications\r\n vm.modified = false;\r\n }\r\n if (elem){\r\n // Empêche l'ouverture d'un nouvel onglet en supprimant l'attribut \"target\"\r\n elem.removeAttribute('target');\r\n elem.setAttribute('aria-label', 'Databases');\r\n vm.modified = true;\r\n }\r\n }\r\n };\r\n }]\r\n};\r\n","/*\r\n OBJECTIFS:\r\n - Toujours afficher l'onglet pour modifier le scope\r\n - Afficher une alerte si les dates correspondent\r\n UTILISATION:\r\n Pour paramétrer l'alerte, il faut modifier le fichier alert_message.js (dans ce dossier)\r\n\r\n REMARQUES:\r\n
\r\n => \"ng-bind-html\" permet d'avoir du texte formatté dans la balise.\r\n*/\r\nmodule.exports = {\r\n bindings: {parentCtrl: '<'},\r\n template: '
',\r\n controllerAs: 'ctrl',\r\n controller: ['$translate', function($translate){\r\n\r\n var vm = this;\r\n\r\n /********************/\r\n /* MESSAGE D'ALERTE */\r\n /********************/\r\n\r\n // récupère le fichier json avec les paramètres de l'alerte\r\n vm.alert = require('./alert_message.js');\r\n\r\n // Par défaut, l'alerte n'est pas considérée comme active\r\n // La valeur est écrasée par la suite si l'alerte est active\r\n vm.active = false;\r\n\r\n // Vérifie dans le fichier json si une alerte est prévue\r\n if (vm.alert.active === true){\r\n\r\n // Teste si les dates correspondent pour l'affichage de l'alerte\r\n var d_now = Date.now();\r\n if ((new Date(vm.alert.begin) < d_now) && (d_now < new Date(vm.alert.end))) {\r\n\r\n // déclenche l'affichage de l'alerte\r\n vm.active = true;\r\n }\r\n }\r\n\r\n // Renvoie le texte en fonction de la langue\r\n vm.get_txt = function(){\r\n var lang = ['en', 'fr'].includes($translate.use()) ? $translate.use():'en';\r\n return vm.active ? vm.alert.txt[lang] : \"\";\r\n }\r\n\r\n /*******************/\r\n /* SCOPE PERMANENT */\r\n /*******************/\r\n\r\n // Rendre permanent l'affichage des onglets permettant de sélectionnet le scope\r\n vm.parentCtrl.showTabsAndScopes = true;\r\n\r\n // console.log(vm);\r\n }\r\n ]};\r\n","\"use strict\";\r\n\r\n/*\r\n OBJECTIF: afficher l'entête de la page.\r\n DESCRIPTION: contient le titre BEAST et le teaser. Si on clique sur le\r\n titre, cela renvoie à la page d'accueil de BEAST.\r\n*/\r\n\r\nmodule.exports = {\r\n bindings: {parentCtrl: '<'},\r\n controllerAs: 'ctrl',\r\n controller: ['$location', '$translate', function($location, $translate) {\r\n var vm = this;\r\n\r\n // Construction de l'URL vers la page d'accueil. Il faut indiquer la vue et la langue.\r\n // Se base sur l'url courante pour fonctionner quel que soit l'environnement.\r\n vm.url = $location.absUrl().split('?')[0] + '?vid=' + vm.parentCtrl.configurationUtil.vid + '&lang=' + $translate.use();\r\n\r\n // console.log(vm.url);\r\n }],\r\n template: `
\r\n

{{ 'mainTitle' | customTranslate }}

\r\n

{{ 'subTitle' | customTranslate }}

\r\n
`\r\n};\r\n","/************************/\r\n/* List of used modules */\r\n/************************/\r\n\r\n/*\r\nLes paquets suivants ne sont pas en usage pour le moment:\r\n- databases: pour l'instant il n'y a pas de personnalisation\r\n*/\r\n\r\n/*************/\r\n/* EPFL part */\r\n/*************/\r\n\r\nimport './briefview';\r\nimport './homepage';\r\nimport './fullView';\r\nimport './filters';\r\nimport './factory';\r\nimport './slsp_mod_epfl';\r\n\r\nconst epfl_modules = [\r\n 'briefviewModule',\r\n 'homepageModule',\r\n 'fullviewModule',\r\n 'filtersModule',\r\n 'factoryModule',\r\n 'epflCourierInfoModule',\r\n];\r\n\r\n/*************/\r\n/* SLSP part */\r\n/*************/\r\n\r\n// import './slsp-courier-info';\r\nimport './slsp/slsp-ill-signin-order-alert';\r\nimport './slsp/prm-locations-after';\r\nimport './slsp/prm-location-items-after';\r\nimport './slsp/slsp-archives-htgi';\r\nimport './slsp/slsp-archives-viewit';\r\nimport './slsp/slsp-http-intercept-requests';\r\nimport './slsp/prm-user-area-expandable-after';\r\nimport './slsp/prm-loan-after';\r\nimport './slsp/prm-personal-info-after';\r\n\r\nconst slsp_modules = [\r\n // 'slspCourierInfo',\r\n 'slspIllSigninOrderAlert',\r\n 'ethLocationsAfterModule',\r\n 'ethLocationItemsAfterModule',\r\n 'slspArchivesHtgi',\r\n 'slspArchivesViewit',\r\n 'slspHttpInterceptRequests',\r\n 'slspUserAreaExpandableAfterModule',\r\n 'slspLoanAfterModule',\r\n 'slspPersonalInfoAfterModule'\r\n];\r\n\r\n\r\n\r\n// import './databases';\r\nvar app = angular.module('viewCustom', [].concat(['angularLoad'],\r\n epfl_modules,\r\n slsp_modules));\r\n","\r\nimport {slspRenewItemTextModule} from './slsp-renew-item-text/slsp-renew-item-text.module';\r\n\r\nexport const slspLoanAfterModule = angular\r\n .module('slspLoanAfterModule', [])\r\n .component('prmLoanAfter', {\r\n bindings: {parentCtrl: '<'},\r\n template: ``\r\n });\r\n\r\nslspLoanAfterModule.requires.push(slspRenewItemTextModule.name);\r\n","//--------Renewstatus display of loan items ---------------------------------------\r\n\r\nexport class slspRenewItemTextController {\r\n\r\n constructor() {\r\n\r\n }\r\n\r\n $onInit() {\r\n try {\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n this.getRenewText = getRenewText;\r\n\r\n function getRenewText() {\r\n if (this.parentCtrl.item.renewstatuses !== undefined && this.parentCtrl.item.renewstatuses.renewstatus[0] !== undefined) {\r\n return this.parentCtrl.item.renewstatuses.renewstatus[0];\r\n }\r\n else {\r\n return\r\n }\r\n }\r\n }\r\n\r\n catch (e) {\r\n console.error(\"***SLSP*** an error occured: slspRenewItemTextController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n}\r\n\r\nslspRenewItemTextController.$inject = [];\r\n\r\n","\r\n\r\n\r\n\r\n\r\n import {slspRenewItemTextController} from './slsp-renew-item-text.controller';\r\n import {slspRenewItemTextHtml} from './slsp-renew-item-text.html';\r\n\r\n export const slspRenewItemTextModule = angular\r\n .module('slspRenewItemTextModule', [])\r\n .controller('slspRenewItemTextController', slspRenewItemTextController)\r\n .component('slspRenewItemTextComponent', {\r\n bindings: {afterCtrl: '<'},\r\n controller: 'slspRenewItemTextController',\r\n template: slspRenewItemTextHtml\r\n })","import {ethLocationItemsFilterModule} from './eth-location-items-filter/eth-location-items-filter.module';\r\nimport {slspIButtonModule} from './slsp-i-button/slsp-i-button.module';\r\n\r\nexport const ethLocationItemsAfterModule = angular\r\n .module('ethLocationItemsAfterModule', [])\r\n .component('prmLocationItemsAfter', {\r\n bindings: {parentCtrl: '<'},\r\n template: ``\r\n });\r\n\r\nethLocationItemsAfterModule.requires.push(ethLocationItemsFilterModule.name);\r\nethLocationItemsAfterModule.requires.push(slspIButtonModule.name);\r\n","export class ethLocationItemsFilterController {\r\n\r\n constructor($timeout, $scope) {\r\n this.$timeout = $timeout;\r\n this.$scope = $scope;\r\n }\r\n\r\n $onInit() {\r\n try{\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n this.$scope.$watch('this.$ctrl.parentCtrl.loc.location.librarycodeTranslation', (newValue, oldValue, scope) => {\r\n \r\n if(!scope.$ctrl.parentCtrl.isLocationsFilterVisible && newValue && newValue != ''){\r\n \r\n this.$scope.$watch('this.$ctrl.parentCtrl.loc.items', (currentItemsArray) => {\r\n\r\n if (angular.isArray(currentItemsArray) && currentItemsArray.length > 1){\r\n \r\n this.$timeout(() => {\r\n scope.$ctrl.parentCtrl.isLocationsFilterVisible = true;\r\n }, 0);\r\n \r\n } \r\n \r\n })\r\n }\r\n\r\n }, true);\r\n \r\n \r\n \r\n \r\n \r\n \r\n }\r\n catch(e){\r\n console.error(\"***SLSP*** an error occured: ethLocationItemsFilterController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n}\r\n\r\nethLocationItemsFilterController.$inject = ['$timeout', '$scope'];\r\n\r\n","/**\r\n* @ngdoc module\r\n* @name ethLocationsFilterModule\r\n*\r\n* @description\r\n*\r\n* Customization for the locations filter:
\r\n* - the locations filter is visible by default\r\n*\r\n* If there is 1 location: prmLocationItemsAfter\r\n*\r\n* If there are multiple locations: prmLocationAfter;\r\n* after all locations: prmLocationsAfter;\r\n* after choosing a location: prmLocationItemsAfter\r\n*\r\n*\r\n* AngularJS Dependencies
\r\n*\r\n*\r\n* CSS/Image Dependencies
\r\n* CSS eth-locations-filter.css\r\n*\r\n*\r\n*/\r\nimport {ethLocationItemsFilterController} from './eth-location-items-filter.controller';\r\n\r\nexport const ethLocationItemsFilterModule = angular\r\n .module('ethLocationItemsFilterModule', [])\r\n .controller('ethLocationItemsFilterController', ethLocationItemsFilterController)\r\n .component('ethLocationItemsFilterComponent', {\r\n bindings: {afterCtrl: '<'},\r\n controller: 'ethLocationItemsFilterController'\r\n })\r\n","\r\n\r\n//--------\"i\" button ---------------------------------------\r\n\r\n\r\n export class slspIButtonController {\r\n\r\n constructor() {}\r\n \r\n $doCheck() {\r\n try{\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n this.getLibrary = getLibrary;\r\n this.getLibraryCode = getLibraryCode;\r\n this.getLanguage = getLanguage;\r\n this.biblinkText = \"Library\";\r\n this.biblinkBase = \"https:\\/\\/registration.slsp.ch\\/libraries\\/\\?library\\=\";\r\n\r\n function getLibrary() {\r\n return this.parentCtrl.currLoc.location.librarycodeTranslation;\r\n \r\n }\r\n function getLibraryCode() {\r\n return this.parentCtrl.currLoc.location.libraryCode;\r\n \r\n }\r\n function getLanguage() {\r\n return this.parentCtrl.userSessionManagerService.$location.$$search.lang;\r\n \r\n }\r\n \r\n }\r\n catch(e){\r\n console.error(\"***SLSP*** an error occured: slspIButtonController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n }\r\n \r\n slspIButtonController.$inject = [];\r\n\r\n "," import {slspIButtonController} from './slsp-i-button.controller';\r\n import {slspIButtonHtml} from './slsp-i-button.html';\r\n \r\n\r\n export const slspIButtonModule = angular\r\n .module('slspIButtonModule', [])\r\n .controller('slspIButtonController', slspIButtonController)\r\n .component('slspIButtonComponent', {\r\n bindings: {afterCtrl: '<'},\r\n controller: 'slspIButtonController',\r\n template: slspIButtonHtml\r\n })","import {ethLocationsFilterModule} from './eth-locations-filter/eth-locations-filter.module';\r\n\r\nexport const ethLocationsAfterModule = angular\r\n .module('ethLocationsAfterModule', [])\r\n .component('prmLocationsAfter', {\r\n bindings: {parentCtrl: '<'},\r\n template: ``\r\n });\r\n\r\nethLocationsAfterModule.requires.push(ethLocationsFilterModule.name);\r\n","export class ethLocationsFilterController {\r\n\r\n constructor($timeout, $scope) {\r\n this.$timeout = $timeout;\r\n this.$scope = $scope;\r\n }\r\n\r\n $onInit() {\r\n try{\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n this.$scope.$watch('this.$ctrl.parentCtrl.locations[0].location.librarycodeTranslation', (newValue, oldValue, scope) => {\r\n if(!scope.$ctrl.parentCtrl.isLocationsFilterVisible && newValue && newValue != ''){\r\n this.$timeout(() => {\r\n scope.$ctrl.parentCtrl.isLocationsFilterVisible = true;\r\n }, 0);\r\n }\r\n }, true);\r\n }\r\n catch(e){\r\n console.error(\"***ETH*** an error occured: ethLocationsFilterController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n}\r\n\r\nethLocationsFilterController.$inject = ['$timeout', '$scope'];\r\n","/**\r\n* @ngdoc module\r\n* @name ethLocationsFilterModule\r\n*\r\n* @description\r\n*\r\n* Customization for the locations filter:
\r\n* - the locations filter is visible by default\r\n*\r\n* If there is 1 location: prmLocationItemsAfter\r\n*\r\n* If there are multiple locations: prmLocationAfter;\r\n* after all locations: prmLocationsAfter;\r\n* after choosing a location: prmLocationItemsAfter\r\n*\r\n*\r\n* AngularJS Dependencies
\r\n*\r\n*\r\n* CSS/Image Dependencies
\r\n* CSS eth-locations-filter.css\r\n*\r\n*\r\n*/\r\nimport {ethLocationsFilterController} from './eth-locations-filter.controller';\r\n\r\nexport const ethLocationsFilterModule = angular\r\n .module('ethLocationsFilterModule', [])\r\n .controller('ethLocationsFilterController', ethLocationsFilterController)\r\n .component('ethLocationsFilterComponent', {\r\n bindings: {afterCtrl: '<'},\r\n controller: 'ethLocationsFilterController'\r\n })\r\n","\r\n\r\n//-----------------------------------------------\r\n\r\n\r\nexport class slspEditPersonalDetailsController {\r\n\r\n constructor($scope, $element) {\r\n this.$scope = $scope;\r\n this.$element = $element;\r\n\r\n }\r\n\r\n $doCheck() {\r\n try {\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n\r\n\r\n\r\n let lang = 'en';\r\n let sms = this.$scope.$root.$$childHead.$ctrl.userSessionManagerService;\r\n if (sms) {\r\n lang = sms.getInterfaceLanguage();\r\n }\r\n\r\n this.detailsBaseEdu = \"https:\\/\\/eduid.ch\\/web\\/change-account-data\\/2\\/?lang=\" + lang;\r\n this.detailsBaseReg = \"https:\\/\\/registration.slsp.ch\\/library-card\\/?lang=\" + lang;\r\n this.exclude = ['STAFF', '11', '12', '13', '14', '15', '16', '91', '92', '99'];\r\n this.grpA = ['11', '91', '92'];\r\n this.grpB = ['12', '13', '14', '15', '16'];\r\n\r\n\r\n this.getPatronGrp = function () {\r\n if (this.parentCtrl.personalInfoService.personalInfo !== undefined) {\r\n let patron = this.parentCtrl.personalInfoService.personalInfo.patronstatus[0].registration[0].institution[0].patronstatuscode;\r\n if (!this.exclude.includes(patron)) {\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n this.grpLabelA = function () {\r\n if (this.parentCtrl.personalInfoService.personalInfo !== undefined) {\r\n let labelA = this.parentCtrl.personalInfoService.personalInfo.patronstatus[0].registration[0].institution[0].patronstatuscode;\r\n if (this.grpA.includes(labelA)) {\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n\r\n this.grpLabelB = function () {\r\n if (this.parentCtrl.personalInfoService.personalInfo !== undefined) {\r\n let labelB = this.parentCtrl.personalInfoService.personalInfo.patronstatus[0].registration[0].institution[0].patronstatuscode;\r\n if (this.grpB.includes(labelB)) {\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n this.buttonMove = function () {\r\n let parentElement = angular.element(document.querySelector('prm-personal-info > div.layout-wrap.layout-align-center-start.layout-row > md-card:nth-child(2)'));\r\n let element = angular.element(document.querySelector('#SLSPeditPersonalDetails'));\r\n parentElement.append(element);\r\n }\r\n\r\n\r\n }\r\n catch (e) {\r\n console.error(\"***SLSP*** an error occured: EditPersonalDetailsController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n}\r\n\r\nslspEditPersonalDetailsController.$inject = ['$scope'];\r\n\r\n","import {slspEditPersonalDetailsController} from './slsp-edit-personal-details.controller';\r\nimport {slspEditPersonalDetailsHtml} from './slsp-edit-personal-details.html';\r\n\r\n\r\nexport const slspEditPersonalDetailsModule = angular\r\n .module('slspEditPersonalDetailsModule', [])\r\n .controller('slspEditPersonalDetailsController', slspEditPersonalDetailsController)\r\n .component('slspEditPersonalDetailsComponent', {\r\n bindings: {afterCtrl: '<'},\r\n controller: 'slspEditPersonalDetailsController',\r\n template: slspEditPersonalDetailsHtml\r\n })","import {slspEditPersonalDetailsModule} from './slsp-edit-personal-details/slsp-edit-personal-details.module';\r\n\r\n\r\nexport const slspPersonalInfoAfterModule = angular\r\n .module('slspPersonalInfoAfterModule', [])\r\n .component('prmPersonalInfoAfter', {\r\n bindings: {parentCtrl: '<'},\r\n template: ``\r\n });\r\n\r\n slspPersonalInfoAfterModule.requires.push(slspEditPersonalDetailsModule.name);\r\n\r\n","export class bcuLangSwitchController {\r\n\r\n constructor($element, $window) {\r\n this.$parent = $element.parent().parent()[0];\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n this.$window = $window;\r\n }\r\n\r\n $onInit() {\r\n try {\r\n \r\n this.languages = [\"de\",\"fr\",\"it\",\"en\"];\r\n if (!this.languages.includes(this.parentCtrl.lang)) {\r\n this.changeLanguage(\"en\");\r\n }\r\n \r\n }\r\n catch (e) {\r\n console.error(\"***BCUFR*** bcuLangSwitchControler $onInit\");\r\n console.error(e.message);\r\n }\r\n };\r\n\r\n changeLanguage(lang) {\r\n \r\n this.parentCtrl.changeLangService.addLangParamToUrl(lang);\r\n let t = this.parentCtrl;\r\n this.parentCtrl.i18nService.setLanguage(lang).then(function(){\r\n t.$timeout(function(){return t.$state.go(t.$state.current,{lang:lang},{reload:!0})})\r\n });\r\n };\r\n\r\n}\r\nbcuLangSwitchController.$inject = ['$element'];","/**\r\n* @ngdoc module\r\n* @name bcuLangSwitchModule\r\n*\r\n* @description\r\n* - Add LangSwitch to user area\r\n* @example\r\n* each view\r\n*\r\n*/\r\nimport {bcuLangSwitchController} from './bcu-lang-switch.controller';\r\n\r\nexport const bcuLangSwitchModule = angular\r\n .module('bcuLangSwitchModule', [])\r\n .controller('bcuLangSwitchController', bcuLangSwitchController)\r\n .component('bcuLangSwitchComponent', {\r\n bindings: {afterCtrl: '<'},\r\n controller: 'bcuLangSwitchController',\r\n// template: ''\r\n template: ''\r\n })\r\n","\r\nexport class slspIllSigninOrderLoggedOutController {\r\n\r\n constructor(slspIllSigninOrderLoggedOutService, $scope) {\r\n this.slspIllSigninOrderLoggedOutService = slspIllSigninOrderLoggedOutService;\r\n this.$scope = $scope;\r\n }\r\n\r\n $doCheck() {\r\n try{\r\n this.parentCtrl = this.afterCtrl.parentCtrl;\r\n this.$scope.usrNme = this.slspIllSigninOrderLoggedOutService.isGuest();\r\n\r\n if (this.$scope.usrNme == true) {\r\n let myEl = angular.element(document.querySelector('primo-explore'));\r\n return myEl.addClass('logged-out')\r\n }\r\n \r\n else {\r\n let myEl = angular.element(document.querySelector('primo-explore'));\r\n return myEl.removeClass('logged-out');\r\n }\r\n }\r\n catch(e){\r\n console.error(\"***SLSP*** an error occured: slspIllSigninOrderLoggedOutController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n}\r\n\r\nslspIllSigninOrderLoggedOutController.$inject = ['slspIllSigninOrderLoggedOutService', '$scope'];\r\n \r\n\r\n","\r\n\r\n //--------ILL Signin Order - if logged out ---------------------------------------\r\n \r\n\r\n import {slspIllSigninOrderLoggedOutController} from './slsp-ill-signin-order-logged-out.controller';\r\n import {slspIllSigninOrderLoggedOutService} from './slsp-ill-signin-order-logged-out.service';\r\n\r\n export const slspIllSigninOrderLoggedOutModule = angular\r\n .module('slspIllSigninOrderLoggedOutModule', [])\r\n .factory('slspIllSigninOrderLoggedOutService', slspIllSigninOrderLoggedOutService)\r\n .controller('slspIllSigninOrderLoggedOutController', slspIllSigninOrderLoggedOutController)\r\n .component('slspIllSigninOrderLoggedOutComponent', {\r\n bindings: {afterCtrl: '<'},\r\n controller: 'slspIllSigninOrderLoggedOutController',\r\n \r\n })\r\n ","\r\n\r\n export const slspIllSigninOrderLoggedOutService = ['jwtHelper', function( jwtHelper ){\r\n\r\n function getDecodedToken(){\r\n try{\r\n if (!sessionStorage){\r\n console.error(\"***SLSP*** no session storage\")\r\n return null;\r\n }\r\n let jwt = sessionStorage.getItem('primoExploreJwt');\r\n if (!jwt){\r\n return null;\r\n }\r\n return jwtHelper.decodeToken(jwt);\r\n }\r\n catch(e){\r\n console.error(\"**SLSP*** an error occured: userService.getDecodedToken:\");\r\n console.error(e.message);\r\n }\r\n }\r\n \r\n function isGuest(){\r\n try{\r\n let decodedToken = getDecodedToken();\r\n if (!decodedToken) {\r\n return null;\r\n }\r\n let userName= decodedToken.userGroup !== 'GUEST'? decodedToken.userName : '';\r\n if (userName){\r\n return false;\r\n }\r\n else{\r\n return true;\r\n }\r\n }\r\n catch(e){\r\n console.error(\"***SLSP*** an error occured: userService.isGuest:\");\r\n console.error(e.message);\r\n }\r\n }\r\n \r\n return {\r\n isGuest: isGuest,\r\n getDecodedToken: getDecodedToken\r\n };\r\n }]\r\n ","import {bcuLangSwitchModule} from './bcu-lang-switch/bcu-lang-switch.module';\r\nimport {slspIllSigninOrderLoggedOutModule} from './slsp-ill-signin-order-logged-out/slsp-ill-signin-order-logged-out.module';\r\n\r\nexport const slspUserAreaExpandableAfterModule = angular\r\n .module('slspUserAreaExpandableAfterModule', [])\r\n .component('prmUserAreaExpandableAfter', {\r\n bindings: {parentCtrl: '<'},\r\n template: ``,\r\n });\r\n\r\nslspUserAreaExpandableAfterModule.requires.push(bcuLangSwitchModule.name);\r\nslspUserAreaExpandableAfterModule.requires.push(slspIllSigninOrderLoggedOutModule.name);","require('./js/slsp-archives-htgi.module.js')\r\nmodule.exports = 'slspArchivesHtgi'\r\n","angular\r\n .module('slspArchivesHtgi', [])\r\n\r\n // \"how to get it\" section for resources of archives MFA, TMA (CMI STAR)\r\n\r\n .controller('ArchivesHtgiController', [function () {\r\n\r\n this.$onInit = function () {\r\n try{\r\n if(!this.parentCtrl.item.pnx.display.source || this.parentCtrl.item.pnx.display.source.length === 0){\r\n return;\r\n }\r\n this.source = this.parentCtrl.item.pnx.display.source[0];\r\n // CMI STAR sources\r\n if(this.source === 'ETH_MaxFrischArchiv' || this.source === 'ETH_ThomasMannArchiv'){\r\n // hide content of htgi section\r\n let section = document.getElementById('full-view-container');\r\n section.classList.add('slsp-archives-hide');\r\n\r\n // get guid of CMIStar\r\n let sourceid = this.parentCtrl.item.pnx.control.originalsourceid[0];\r\n let guid = sourceid.substring(sourceid.lastIndexOf(':') + 1);\r\n\r\n // different sources: concat url\r\n if(this.source === 'ETH_ThomasMannArchiv'){\r\n this.url = 'http://www.online.tma.ethz.ch/home/#/content/' + guid;\r\n // only for test\r\n //this.label = 'Detailed information in Thomas Mann-Archiv Online (metadata only)';\r\n }\r\n else if (this.source === 'ETH_MaxFrischArchiv') {\r\n this.url = 'http://maxfrischarchiv-online.ethz.ch/home/#/content/' + guid;\r\n // only for test\r\n //this.label = 'Request via Max Frisch-Archiv Online';\r\n }\r\n }\r\n }\r\n catch(e){\r\n console.error(\"***SLSP*** an error occured: ArchivesHtgiController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n }])\r\n\r\n .component('almaHtgiSvcAfter', {\r\n bindings: { parentCtrl: '<' },\r\n controller: 'ArchivesHtgiController',\r\n template: `\r\n
\r\n \r\n \r\n {{('customized.archives.' + $ctrl.source + '.linktext' | translate)}}\r\n {{$ctrl.label}}\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n No request possible. The digitized item can be consulted in the Thomas Mann Archives reading room upon advance registration (\r\n \r\n Contact\r\n \r\n \r\n ).\r\n
\r\n
\r\n
\r\n
\r\n Informationen zu Bestellung und Benutzung siehe\r\n \r\n Bedienungshinweise\r\n \r\n \r\n .\r\n
\r\n
\r\n
\r\n `\r\n });\r\n","require('./js/slsp-archives-viewit.module.js')\r\nmodule.exports = 'slspArchivesViewit'\r\n","angular\r\n.module('slspArchivesViewit', [])\r\n\r\n .component('prmSearchResultAvailabilityLineAfter', {\r\n bindings: { parentCtrl: '<' },\r\n controller: 'ArchivesAvailabilityLineController',\r\n template:''\r\n })\r\n\r\n .component('prmAlmaViewitAfter', {\r\n bindings: { parentCtrl: '<' },\r\n controller: 'ArchivesViewitController',\r\n template: `\r\n
\r\n \r\n \r\n {{('customized.archives.' + $ctrl.source + '.linktext' | translate)}}\r\n {{$ctrl.label}}\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n Informationen zu Bestellung und Benutzung siehe\r\n \r\n Bedienungshinweise\r\n \r\n \r\n .\r\n
\r\n
\r\n
\r\n `\r\n })\r\n\r\n // viewit section for archives when there are only partial digitized items, e.g. \"ETH Hochschularchiv\" (CMI STAR)\r\n .controller('ArchivesViewitController', ['$translate', function ($translate) {\r\n this.$onInit = function () {\r\n try{\r\n if(!this.parentCtrl.item.pnx.display.source || this.parentCtrl.item.pnx.display.source.length === 0){\r\n return;\r\n }\r\n this.source = this.parentCtrl.item.pnx.display.source[0];\r\n // CMI STAR sources\r\n if(this.source === 'ETH_Hochschularchiv'){\r\n if(this.parentCtrl.item.delivery.GetIt1 && this.parentCtrl.item.delivery.GetIt1.length > 0 && this.parentCtrl.item.delivery.GetIt1[0].links && this.parentCtrl.item.delivery.GetIt1[0].links.length > 0){\r\n\r\n // there is an online resource: return and do nothing\r\n let aOnlineLink = this.parentCtrl.item.delivery.GetIt1[0].links.filter( l => {\r\n if(l.isLinktoOnline && l.link !== ''){\r\n return true;\r\n }\r\n return false;\r\n });\r\n if (aOnlineLink.length > 0) {\r\n return;\r\n }\r\n\r\n // there is no online resource\r\n // change section heading\r\n $translate('nui.getit.service_howtogetit').then((translation) => {\r\n let fullView = document.getElementById('fullView');\r\n angular.element(fullView.querySelector(\"h4[translate='nui.getit.service_viewit']\")).text(translation);\r\n angular.element(fullView.querySelector(\"#services-index span[translate='nui.getit.service_viewit']\")).text(translation);\r\n });\r\n\r\n }\r\n // hide content of viewit section\r\n let section = document.getElementById('full-view-container');\r\n section.classList.add('slsp-archives-hide');\r\n\r\n // get guid of CMIStar\r\n let sourceid = this.parentCtrl.item.pnx.control.originalsourceid[0];\r\n let guid = sourceid.substring(sourceid.lastIndexOf(':') + 1);\r\n\r\n // different sources: concat url\r\n if(this.source === 'ETH_Hochschularchiv'){\r\n this.url = 'http://archivdatenbank-online.ethz.ch/hsa/#/content/' + guid;\r\n // only for test\r\n //this.label = 'Bestellen über Hochschularchiv Online';\r\n }\r\n }\r\n }\r\n catch(e){\r\n console.error(\"***SLSP*** an error occured: ArchivesViewitController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n }])\r\n\r\n // change availability line, if there is no digitization\r\n .controller('ArchivesAvailabilityLineController', ['$translate', function ($translate) {\r\n this.$onInit = function () {\r\n try{\r\n this.changeButton = false;\r\n if(!this.parentCtrl.result.pnx.display.source || this.parentCtrl.result.pnx.display.source.length === 0){\r\n return;\r\n }\r\n this.source = this.parentCtrl.result.pnx.display.source[0];\r\n if(!(this.source === 'ETH_Hochschularchiv'))return;\r\n if(!this.parentCtrl.result.delivery.GetIt1 || this.parentCtrl.result.delivery.GetIt1.length == 0 || !this.parentCtrl.result.delivery.GetIt1[0].links || this.parentCtrl.result.delivery.GetIt1[0].links.length == 0)return;\r\n\r\n let aOnlineLink = this.parentCtrl.result.delivery.GetIt1[0].links.filter( l => {\r\n if(l.isLinktoOnline && l.link !== ''){\r\n return true;\r\n }\r\n return false;\r\n });\r\n if (aOnlineLink.length === 0) {\r\n // there is no online resource\r\n $translate('delivery.code.no_inventory').then((translation) => {\r\n this.changeButton = true;\r\n this.changeButtonText = translation;\r\n });\r\n let availabilityLine = this.parentCtrl.$element[0];\r\n if(availabilityLine) {\r\n availabilityLine.classList.add('slsp-hsa-no-online');\r\n }\r\n }\r\n }\r\n catch(e){\r\n console.error(\"***SLSP*** an error occured: ArchivesAvailabilityLineController\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n\r\n this.$doCheck = function () {\r\n try{\r\n if (this.changeButton){\r\n let availabilityLine = this.parentCtrl.$element[0];\r\n let button = availabilityLine.querySelector('.availability-status');\r\n if(angular.element(button) && angular.element(button).length > 0){\r\n angular.element(button).html(this.changeButtonText);\r\n this.changeButton = false;\r\n this.changeButtonText = '';\r\n }\r\n }\r\n }\r\n catch(e){\r\n console.error(\"***ETH*** an error occured: ArchivesAvailabilityLineController $doCheck\\n\\n\");\r\n console.error(e.message);\r\n }\r\n }\r\n }])\r\n","require('./js/slsp-http-intercept-requests.module.js')\r\nmodule.exports = 'slspHttpInterceptRequests'","export const slspHttpInterceptRequests = angular.module('slspHttpInterceptRequests', ['ng'])\r\n .config(['$httpProvider', ($httpProvider) => {\r\n $httpProvider.interceptors.push(['$q', ($q) => {\r\n return {\r\n 'request': (request) => {\r\n return request\r\n },\r\n 'requestError': (request) => {\r\n return $q.reject(request)\r\n },\r\n 'responseError': (response) => {\r\n return $q.reject(response)\r\n },\r\n 'response': (response) => {\r\n try {\r\n if (/primaws\\/rest\\/priv\\/myaccount\\/requests/.test(response.config.url)) {\r\n if (response.status == 200 && response.data.status == \"ok\") {\r\n let interfaceLanguage = angular.element(document.querySelector('primo-explore')).injector().get('$rootScope').$$childHead.$ctrl.userSessionManagerService.getUserLanguage() ||\r\n window.appConfig['primo-view']['attributes-map'].interfaceLanguage\r\n\r\n let list_of_hold_states = {\r\n 'en': [\"in transit\", \"in process\", \"on hold shelf\"],\r\n 'de': [\"transfer\", \"in bearbeitung\", \"bereitgestellt\"],\r\n 'fr': [\"en cours de transfert\", \"en cours\", \"sur le rayon des réservations\"],\r\n 'it': [\"in transito\", \"in processo\", \"scaffale prenotazioni\"]\r\n }\r\n let list_of_photocopy_states = {\r\n 'en': [\"in transit\", \"in process\"],\r\n 'de': [\"transfer\", \"in bearbeitung\"],\r\n 'fr': [\"en cours de transfert\", \"en cours\"],\r\n 'it': [\"in transito\", \"in processo\"]\r\n }\r\n if (Object.keys(list_of_hold_states).includes(interfaceLanguage)) {\r\n let list_of_hold_states_regexp = RegExp(list_of_hold_states[interfaceLanguage].map(m => m.toLowerCase()).join('|'))\r\n // rewrite cancellable holds\r\n response.data.data.holds.hold.map((m) => {\r\n if (list_of_hold_states_regexp.test(m.holdstatus.toLowerCase())) {\r\n m.cancel = 'N'\r\n }\r\n })\r\n }\r\n else {\r\n throw `No mapping found for holds: ${interfaceLanguage}`\r\n }\r\n\r\n if (Object.keys(list_of_photocopy_states).includes(interfaceLanguage)) {\r\n let list_of_photocopy_states_regexp = RegExp(list_of_photocopy_states[interfaceLanguage].map(m => m.toLowerCase()).join('|'))\r\n // rewrite cancellable photocopies\r\n response.data.data.photocopies.photocopy.map((m) => {\r\n if (list_of_photocopy_states_regexp.test(m.requeststatus.toLowerCase())) {\r\n m.cancel = 'N'\r\n }\r\n })\r\n }\r\n else {\r\n throw `No mapping found for photocopies: ${interfaceLanguage}`\r\n }\r\n }\r\n }\r\n }\r\n catch (error) {\r\n console.error(error);\r\n }\r\n return response;\r\n }\r\n }\r\n }])\r\n }])\r\n","require('./js/slsp-ill-signin-order-alert.module.js')\r\nmodule.exports = 'slspIllSigninOrderAlert'","//--------ILL Signin Order - if Alert Message ---------------------------------------\r\n\r\nangular\r\n .module('slspIllSigninOrderAlert', [])\r\n\r\n .controller('AlertMsgController', ['$scope', function ($scope) {\r\n var vm = this;\r\n vm.getAlert = getAlert\r\n\r\n function getAlert() {\r\n var ga = vm.parentCtrl.almaHowToGetitService.reqAlert._htmlMsg;\r\n var myEl2 = angular.element(document.querySelector('primo-explore'));\r\n\r\n if (ga.length > 0) {\r\n return myEl2.addClass('alert');\r\n\r\n }\r\n else {\r\n\r\n return myEl2.removeClass('alert');\r\n\r\n }\r\n }\r\n\r\n }])\r\n\r\n .component('almaHowovpAfter', {\r\n bindings: { parentCtrl: '<' },\r\n controller: 'AlertMsgController',\r\n template: '
{{$ctrl.getAlert()}}
'\r\n });\r\n","/* ---------------- */\r\n/* - VERSION EPFL - */\r\n/* ---------------- */\r\n\r\n/*\r\n\r\nAVERTISSEMENT: ce module est très différent de sa version originale d'SLSP.\r\n\r\nIl doit donc être considéré comme réécrit et les ajouts ne sont pas indiqués.\r\n\r\nCe module permet d'afficher les boutons renvoyant à SWITCH edu-ID.\r\n\r\nFONCTIONNALITES:\r\n- Mettre l'EPFL en tête des possibilités de retrait.\r\n- Afficher les messages personnalisés pour les frais.\r\n\r\n*/\r\n\r\n angular\r\n .module('epflCourierInfoModule', [])\r\n\r\n .controller('CourierInfoController', ['$filter', '$element', function ($filter, $element, $compile, $scope, $rootScope) {\r\n var vm = this;\r\n\r\n //shortcut for convenience\r\n vm.form = $element[0].parentElement;\r\n\r\n //function for inserting block\r\n vm.$doCheck = function() {\r\n let form = false;\r\n let formLength = 2;\r\n // console.log(vm.form);\r\n if (vm.form.children[0].children[1] !== undefined && (vm.form.children[0].children[1].children[0] !== undefined || vm.typeFeeAlert()=='costWarningPEB')) {\r\n form = vm.form.children[0].children[1].children[0];\r\n if (vm.typeFeeAlert()=='costWarningPEB'){\r\n formLength = 3;\r\n }\r\n }\r\n else if (vm.form.children[0].children[0] !== undefined && vm.form.children[0].children[0].children[0] !== undefined) {\r\n form = vm.form.children[0].children[0].children[0];\r\n formLength = 3;\r\n }\r\n // console.log(vm.typeFeeAlert());\r\n\r\n //create and insert info block if not present\r\n // if (form){\r\n // // console.log('---' + String(formLength) + ' - ' + String(form.children.length));}\r\n if (form && form.children.length == formLength && form.children.length > 1 || vm.hasOwnProperty('currentTypeFeeAlert') &&\r\n vm.currentTypeFeeAlert != vm.typeFeeAlert()) {\r\n // console.log('cccc---' + String(formLength) + ' - ' + String(form.children.length));\r\n vm.currentTypeFeeAlert = vm.typeFeeAlert();\r\n var htmlwarning = `

${vm.getFeeAlert()}

`;\r\n if (vm.typeFeeAlert()=='costWarningScan') {\r\n var txt = $filter('customTranslate')('illButton');\r\n if (vm.get_peb_button()){\r\n var fn = `javascript:(function() {\r\n for (var elem of document.getElementsByTagName('span')) {\r\n if (elem.getAttribute('translate') === 'AlmaResourceSharing' &&\r\n elem.parentNode.className.indexOf('greenbutton') === -1)\r\n {\r\n elem.click();\r\n break;\r\n }\r\n };})()`;}\r\n else {\r\n var fn = `javascript:(function() {window.location.href = window.location.origin + '/discovery/blankIll?vid=${vm.parentCtrl.vid}'})()`;\r\n }\r\n\r\n\r\n htmlwarning += `

${txt}

`;\r\n\r\n }\r\n htmlwarning += `

${vm.parentCtrl.$translate.instant('customize.fullview.feesLinkText')}

`;\r\n var htmlcompiled = angular.element(htmlwarning)[0];\r\n\r\n // console.log('---' + String(formLength) + ' - ' + String(form.children.length));\r\n if (form.children.length == formLength) {\r\n // console.log('---' + String(formLength) + ' - ' + String(form.children.length));\r\n form.insertBefore(htmlcompiled, form.children[formLength - 1]);\r\n } else {\r\n // console.log(String(formLength) + ' - ' + String(form.children.length));\r\n form.children[form.children.length - 2].replaceWith(htmlcompiled);\r\n }\r\n }\r\n }\r\n\r\n // Remonte l'EPFL dans la liste des bibliothèques\r\n Object.defineProperty(vm.parentCtrl, \"form\", {\r\n configurable: !0,\r\n get: function(){\r\n // Mettre l'EPFL en première position\r\n var form = this.getFilteredForm(['label', 'multiLabel'], false);\r\n if (!vm.hasOwnProperty('pickupLocationsListOrdered')){\r\n for (var i = 0; i < form.length; i++){\r\n if (form[i].key == 'pickupInstitution'){\r\n function compare( a, b ){\r\n var onTopInstitutions = ['41SLSP_EPF', '41SLSP_EPFL'];\r\n a = onTopInstitutions.indexOf(a.value);\r\n b = onTopInstitutions.indexOf(b.value);\r\n if (a == b) {return 0};\r\n return a < b ? 1 : -1;\r\n }\r\n form[i].options.sort(compare);\r\n vm['pickupLocationsListOrdered'] = true;\r\n }\r\n }\r\n }\r\n return form;\r\n }\r\n }\r\n );\r\n\r\n // Vérifie si l'EPFL est la provenance de l'exemplaire sélectionné\r\n vm.isEPFL = function() {\r\n return vm.parentCtrl.requestService && vm.parentCtrl.requestService._service['link-to-service'].indexOf('institution=41SLSP_EPF') > 0 ? true : false;\r\n }\r\n\r\n vm.linkBase = \"https:\\/\\/slsp.ch\\/fees\";\r\n\r\n // Personnalisation du message des frais\r\n vm.typeFeeAlert = function() {\r\n // console.log(vm.parentCtrl.requestHeader);\r\n if (['almaRequest.header', 'almaRequestOther.header', 'almaItemRequest.header'].includes(vm.parentCtrl.requestHeader)) {\r\n return 'costWarningNetworkLoan'; // $filter('customTranslate')(costWarningNetworkLoan');\r\n } else if (['almaDigitization.header',\r\n 'almaDigitizationOther.header',\r\n 'almaItemDigitization.header']\r\n .includes(vm.parentCtrl.requestHeader)) {\r\n return vm.isEPFL() ? 'costWarningScanEPFL' : 'costWarningScan';\r\n } else if (vm.parentCtrl.requestHeader === 'almaResourceSharing.header') {\r\n return 'costWarningPEB';\r\n } else {\r\n return 'costWarningGeneral';\r\n }\r\n }\r\n vm.getFeeAlert = function() {\r\n // console.log(vm.typeFeeAlert());\r\n return $filter('customTranslate')(vm.typeFeeAlert());\r\n }\r\n\r\n // Récupère le bouton PEB de la page afin de simuler un clic dessus\r\n vm.get_peb_button = function(){\r\n var allElements = document.getElementsByTagName('span');\r\n for (var i = 0, n = allElements.length; i < n; i++) {\r\n if (allElements[i].getAttribute('translate') === 'AlmaResourceSharing' &&\r\n allElements[i].parentNode.className.indexOf('greenbutton') === -1)\r\n {\r\n return allElements[i];\r\n }\r\n }\r\n\r\n }\r\n\r\n // Fonction simulant un clic sur le bouton PEB quand on clique sur les\r\n // frais.\r\n vm.click_peb = function(){\r\n var button = vm.get_peb_button();\r\n if (button) {\r\n button.click();\r\n } else {\r\n window.location.href = window.location.origin + '/discovery/blankIll?vid=' + vm.parentCtrl.vid;\r\n }\r\n }\r\n // console.log(vm);\r\n\r\n }])\r\n\r\n .component('prmRequestAfter', {\r\n bindings: { parentCtrl: '<' },\r\n controller: 'CourierInfoController',\r\n });\r\n","require('./epfl-courier-info.module.js')\r\nmodule.exports = 'epflCourierInfoModule'\r\n"]} \ No newline at end of file