@digital-blueprint/sublibrary-app
Version:
[GitHub Repository](https://github.com/digital-blueprint/sublibrary-app) | [npmjs package](https://www.npmjs.com/package/@digital-blueprint/sublibrary-app) | [Unpkg CDN](https://unpkg.com/browse/@digital-blueprint/sublibrary-app/) | [Sublibrary Bundle](ht
106 lines (101 loc) • 23.8 kB
JavaScript
let e=e=>e,t,n,r;function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),n.push.apply(n,r)}return n}function a(e){for(var t=1;t<arguments.length;t++){var n=arguments[t]==null?{}:arguments[t];t%2?i(Object(n),!0).forEach(function(t){o(e,t,n[t])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):i(Object(n)).forEach(function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))})}return e}function o(e,t,n){return(t=s(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function s(e){var t=c(e,`string`);return typeof t==`symbol`?t:t+``}function c(e,t){if(typeof e!=`object`||!e)return e;var n=e[Symbol.toPrimitive];if(n!==void 0){var r=n.call(e,t||`default`);if(typeof r!=`object`)return r;throw TypeError(`@ must return a primitive value.`)}return(t===`string`?String:Number)(e)}
/*!
* License: LGPL-2.1-or-later
* Dependencies:
*
* @webcomponents/scoped-custom-element-registry: BSD-3-Clause
* @dbp-toolkit/app-shell: LGPL-2.1-or-later
* @dbp-toolkit/language-select: LGPL-2.1-or-later
* @dbp-toolkit/auth: LGPL-2.1-or-later
* lit-html: BSD-3-Clause
* @dbp-toolkit/notification: LGPL-2.1-or-later
* @dbp-toolkit/theme-switcher: LGPL-2.1-or-later
* universal-router: MIT
* @dbp-toolkit/matomo: LGPL-2.1-or-later
* xtend: MIT
* fuzzy: (MIT)
* suggestions: ISC
* keycloak-js: Apache-2.0
* @dbp-toolkit/common: LGPL-2.1-or-later
* jquery: MIT
* select2: MIT
* @dbp-toolkit/resource-select: LGPL-2.1-or-later
* i18next: MIT
* @lit/reactive-element: BSD-3-Clause
* lit-element: BSD-3-Clause
* @open-wc/dedupe-mixin: MIT
* @open-wc/scoped-elements: MIT
* dialog-polyfill: BSD
* datatables.net: MIT
* datatables.net-responsive: MIT
* datatables.net-dt: MIT
* datatables.net-responsive-dt: MIT
* jszip: (MIT OR GPL-3.0-or-later)
* datatables.net-buttons: MIT
* datatables.net-buttons-dt: MIT
* @dbp-toolkit/data-table-view: LGPL-2.1-or-later
* @dbp-toolkit/person-select: LGPL-2.1-or-later
*/
import{d as l,i as u,n as d,o as f,r as p}from"./library-select.BChQfqNA.js";import{B as m,C as h,E as g,F as _,H as v,N as y,O as b,T as x,V as S,b as C,g as w,o as T,s as E,v as D,y as O}from"./styles.D8JNhv4k.js";const k=(e,t,n=``)=>{let r=t[`hydra:member`];if(r!==void 0){for(let t of r)if(t[n]===e)return t}};function A(){return{errorLoading:function(){return`Die Ergebnisse konnten nicht geladen werden.`},inputTooLong:function(e){return`Bitte `+(e.input.length-e.maximum)+` Zeichen weniger eingeben`},inputTooShort:function(e){return`Bitte `+(e.minimum-e.input.length)+` Zeichen mehr eingeben, es kann nach mehreren Teilen von Namen gesucht werden`},loadingMore:function(){return`Lade mehr Ergebnisse…`},maximumSelected:function(e){var t=`Sie können nur `+e.maximum+` Eintr`;return e.maximum===1?t+=`ag`:t+=`äge`,t+=` auswählen`,t},noResults:function(){return`Keine Übereinstimmungen gefunden`},searching:function(){return`Suche…`},removeAllItems:function(){return`Entferne alle Gegenstände`}}}function j(){return{errorLoading:function(){return`The results could not be loaded.`},inputTooLong:function(e){var t=e.input.length-e.maximum,n=`Please delete `+t+` character`;return t!=1&&(n+=`s`),n},inputTooShort:function(e){return`Please enter `+(e.minimum-e.input.length)+` or more characters, you can also search for multiple parts of names`},loadingMore:function(){return`Loading more results…`},maximumSelected:function(e){var t=`You can only select `+e.maximum+` item`;return e.maximum!=1&&(t+=`s`),t},noResults:function(){return`No results found`},searching:function(){return`Searching…`},removeAllItems:function(){return`Remove all items`}}}var M={"person-select":{"login-required":`Anmeldung erforderlich`,placeholder:`Bitte wählen Sie eine Person aus`}},N={"person-select":{"login-required":`Login required`,placeholder:`Please select a person`}};function P(){return v({en:N,de:M},`de`,`en`)}var F=l(u(),1),I=l(p(),1),L=class i extends E(g(w),P){constructor(){super(),Object.assign(i.prototype,f),this.auth={},this.entryPointUrl=null,this.$select=null,this.active=!1,this.selectId=`person-select-`+_(24),this.value=``,this.object=null,this.ignoreValueUpdate=!1,this.isSearching=!1,this.lastResult={},this.showReloadButton=!1,this.reloadButtonTitle=``,this.disabled=!1,this.localDataAttributes=[],this._onDocumentClicked=this._onDocumentClicked.bind(this),(0,I.default)(window,F.default)}static get scopedElements(){return{"dbp-icon":b}}$(e){return(0,F.default)(this.shadowRoot.querySelector(e))}static get properties(){return a(a({},super.properties),{},{active:{type:Boolean,attribute:!1},entryPointUrl:{type:String,attribute:`entry-point-url`},value:{type:String},object:{type:Object,attribute:!1},localDataAttributes:{type:Array},showReloadButton:{type:Boolean,attribute:`show-reload-button`},reloadButtonTitle:{type:String,attribute:`reload-button-title`},auth:{type:Object},disabled:{type:Boolean,reflect:!0}})}clear(){this.object=null,(0,F.default)(this).attr(`data-object`,``),(0,F.default)(this).data(`object`,null),this.value=``,(0,F.default)(this).attr(`value`,``),this.$select.val(null).trigger(`change`).trigger(`select2:unselect`),this.dispatchEvent(new CustomEvent(`change`,{detail:{value:``},bubbles:!0}))}connectedCallback(){super.connectedCallback(),document.addEventListener(`click`,this._onDocumentClicked),this.updateComplete.then(()=>{this.$select=this.$(`#`+this.selectId),this.select2IsInitialized()||this.initSelect2()});let e=this.getAttribute(`local-data-attributes`);if(e)try{this.localDataAttributes=JSON.parse(e)}catch(e){console.error(`local-data-attributes attribute must be a JSON array of strings`,e.message)}}disconnectedCallback(){document.removeEventListener(`click`,this._onDocumentClicked),super.disconnectedCallback()}_onDocumentClicked(e){if(!e.composedPath().includes(this)){let e=this.$(`#`+this.selectId);e.length&&this.select2IsInitialized()&&e.select2(`close`)}}initSelect2(e=!1){let t=this._i18n,n=this,r=(0,F.default)(this);if(this.$select===null||this.entryPointUrl===null)return!1;let i=T(this.entryPointUrl,`/base/people`);if(this.$select&&this.$select.hasClass(`select2-hidden-accessible`)&&(this.$select.select2(`destroy`),this.$select.off(`select2:select`),this.$select.off(`select2:closing`)),this.$select.select2({width:`100%`,language:this.lang===`de`?A():j(),minimumInputLength:2,allowClear:!0,placeholder:this.authenticated()?t.t(`person-select.placeholder`):t.t(`person-select.login-required`),dropdownParent:this.$(`#person-select-dropdown`),ajax:{delay:500,url:i,contentType:`application/ld+json`,beforeSend:function(e){e.setRequestHeader(`Authorization`,`Bearer `+n.auth.token),n.isSearching=!0},data:e=>this.getCollectionQueryParameters(this,e.term),processResults:function(e){n.$(`#person-select-dropdown`).addClass(`select2-bug`),n.lastResult=e;let t=e[`hydra:member`],r=[];return t.forEach(e=>{r.push({id:e[``],text:n.formatPerson(n,e)})}),{results:r}},error:(e,t,n)=>{this.handleXhrError(e,t,n)},complete:(e,t)=>{n.isSearching=!1}}}).on(`select2:clear`,function(e){n.clear()}).on(`select2:select`,function(e){n.$(`#person-select-dropdown`).removeClass(`select2-bug`);let t=e.params.data.id;n.object=k(t,n.lastResult),r.attr(`data-object`,JSON.stringify(n.object)),r.data(`object`,n.object),r.attr(`value`)!==t&&(n.ignoreValueUpdate=!0,r.attr(`value`,t),n.dispatchEvent(new CustomEvent(`change`,{detail:{value:t},bubbles:!0})))}).on(`select2:closing`,e=>{n.isSearching&&e.preventDefault()}),!e&&this.value!==``&&this.authenticated()){let e=T(this.entryPointUrl,this.value),t=new URLSearchParams(this.getItemQueryParameters(this)).toString();t&&(e+=`?${t}`),fetch(e,{headers:{"Content-Type":`application/ld+json`,Authorization:`Bearer `+this.auth.token}}).then(e=>{if(!e.ok)throw e;return e.json()}).then(e=>{n.object=e;let t=e[``],i=new Option(n.formatPerson(this,e),t,!0,!0);r.attr(`data-object`,JSON.stringify(e)),r.data(`object`,e),n.$select.append(i).trigger(`change`),n.dispatchEvent(new CustomEvent(`change`,{detail:{value:t},bubbles:!0}))}).catch(e=>{console.log(e),n.clear()})}return!0}getItemQueryParameters(e){let t={};return this.addIncludeLocalQueryParameter(e,t),t}getCollectionQueryParameters(e,t){let n=this.getFilterQueryParameters(e,t);return this.addIncludeLocalQueryParameter(e,n),n}getFilterQueryParameters(e,t){return i.getFilterQueryParametersDefault(e,t)}static getFilterQueryParametersDefault(e,t){return{search:t.trim(),sort:`familyName`}}addIncludeLocalQueryParameter(e,t){this.localDataAttributes.length>0&&(t.includeLocal=this.localDataAttributes.join(`,`))}formatPerson(e,t){let n=t.givenName??``;t.familyName&&(n+=` ${t.familyName}`);let r=this.formatLocalData(e,t);return r&&(n+=` ${r}`),n}static formatPersonDefault(e,t){let n=t.givenName??``;t.familyName&&(n+=` ${t.familyName}`);let r=i.formatLocalDataDefault(e,t);return r&&(n+=` ${r}`),n}formatLocalData(e,t){return i.formatLocalDataDefault(e,t)}static formatLocalDataDefault(e,t){let n=t.localData??{};return Object.values(n).length===0?``:`(${Object.values(n).join(`, `)})`}update(e){super.update(e),e.forEach((e,t)=>{switch(t){case`lang`:this.select2IsInitialized()&&this.initSelect2(!0);break;case`value`:!this.ignoreValueUpdate&&this.select2IsInitialized()&&this.initSelect2(),this.ignoreValueUpdate=!1;break;case`entryPointUrl`:this.initSelect2(!0);break;case`auth`:this.active=this.authenticated(),this.active&&(!e||!e.token)&&this.initSelect2();break}})}select2IsInitialized(){return this.$select!==null&&this.$select.hasClass(`select2-hidden-accessible`)}reloadClick(){this.object!==null&&this.dispatchEvent(new CustomEvent(`change`,{detail:{value:this.value},bubbles:!0}))}authenticated(){return(this.auth.token||``)!==``}static get styles(){return[x(),C(),D(),O(),h(),S(t||=e`
#person-select-dropdown {
position: relative;
}
.select2-control.control {
width: 100%;
}
.field .button.control {
display: flex;
align-items: center;
justify-content: center;
border: var(--dbp-border);
border-color: var(--dbp-muted);
-moz-border-radius-topright: var(--dbp-border-radius);
-moz-border-radius-bottomright: var(--dbp-border-radius);
line-height: 100%;
}
.field .button.control dbp-icon {
top: 0;
}
/* https://github.com/select2/select2/issues/5457 */
.select2-bug .loading-results {
display: none !important;
}
.select2-results__option.loading-results,
{
background-image: url("")
background-repeat: no-repeat;
padding-left: 35px;
background-position: 10px 50%;
}
`)]}render(){let t=this._i18n;return m(n||=e`
<link rel="stylesheet" href="${0}" />
<div class="select">
<div class="field has-addons">
<div class="select2-control control">
<!-- https://select2.org-->
<select
id="${0}"
name="person"
class="select"
?disabled=${0}>
${0}
</select>
</div>
<a
class="control button"
id="reload-button"
?disabled=${0}
="${0}"
style="display: ${0}"
title="${0}">
<dbp-icon name="reload"></dbp-icon>
</a>
</div>
<div id="person-select-dropdown"></div>
</div>
`,y(d),this.selectId,!this.active||this.disabled,this.authenticated()?``:m(r||=e`
<option value="" disabled selected>
${0}
</option>
`,t.t(`person-select.login-required`)),this.object===null,this.reloadClick,this.showReloadButton?`flex`:`none`,this.reloadButtonTitle)}};export{L as t};
//# sourceMappingURL=src.Cbh7eIOt.js.map