UNPKG

@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

384 lines (377 loc) 24.6 kB
let _ = t => t, _t3, _t4, _t5; function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } /*! * 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/common: LGPL-2.1-or-later * @dbp-toolkit/auth: LGPL-2.1-or-later * @dbp-toolkit/notification: LGPL-2.1-or-later * @dbp-toolkit/theme-switcher: LGPL-2.1-or-later * path-to-regexp: MIT * universal-router: MIT * generateUrls: MIT * @dbp-toolkit/matomo: LGPL-2.1-or-later * @dbp-toolkit/person-select: LGPL-2.1-or-later */ import { e, s as t, $ as i, b as s } from "./library-select.Cpz1ozX8.es.js"; import { a as n, S as o, A as r, m as a, I as A, g as l, b as c, h, v as u, n as d, i as g, p, x as m } from "./notification.BYDDIHux.es.js"; import { c as b } from "./utils.C137cI6N.es.js"; var B = { "person-select": { "login-required": "Anmeldung erforderlich", placeholder: "Bitte wählen Sie eine Person aus" } }, C = { "person-select": { "login-required": "Login required", placeholder: "Please select a person" } }; class w extends o(r) { constructor() { super(), Object.assign(w.prototype, e), this.auth = {}, this._i18n = n({ en: C, de: B }, "de", "en"), this.lang = this._i18n.language, this.entryPointUrl = null, this.$select = null, this.active = !1, this.selectId = "person-select-" + a(24), this.value = "", this.object = null, this.ignoreValueUpdate = !1, this.isSearching = !1, this.lastResult = {}, this.showReloadButton = !1, this.reloadButtonTitle = "", this.disabled = !1, this._onDocumentClicked = this._onDocumentClicked.bind(this), t(window, i); } static get scopedElements() { return { "dbp-icon": A }; } $(e) { return i(this.shadowRoot.querySelector(e)); } static get properties() { return _extends({}, super.properties, { lang: { type: String }, active: { type: Boolean, attribute: !1 }, entryPointUrl: { type: String, attribute: "entry-point-url" }, value: { type: String }, object: { type: Object, attribute: !1 }, 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, i(this).attr("data-object", ""), i(this).data("object", null), this.value = "", i(this).attr("value", ""), this.$select.val(null).trigger("change").trigger("select2:unselect"); } connectedCallback() { super.connectedCallback(), document.addEventListener("click", this._onDocumentClicked), this.updateComplete.then(() => { this.$select = this.$("#" + this.selectId), this.select2IsInitialized() || this.initSelect2(); }); } disconnectedCallback() { document.removeEventListener("click", this._onDocumentClicked), super.disconnectedCallback(); } _onDocumentClicked(e) { if (!e.composedPath().includes(this)) { const _e = this.$("#" + this.selectId); _e.length && this.select2IsInitialized() && _e.select2("close"); } } initSelect2(e = !1) { const t = this._i18n, s = this, n = i(this); if (null === this.$select || null === this.entryPointUrl) return !1; const o = b(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: "de" === this.lang ? { 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 1 === e.maximum ? t += "ag" : t += "äge", t += " auswählen"; }, noResults: function () { return "Keine Übereinstimmungen gefunden"; }, searching: function () { return "Suche…"; }, removeAllItems: function () { return "Entferne alle Gegenstände"; } } : { errorLoading: function () { return "The results could not be loaded."; }, inputTooLong: function (e) { var t = e.input.length - e.maximum, i = "Please delete " + t + " character"; return 1 != t && (i += "s"), i; }, 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 1 != e.maximum && (t += "s"), t; }, noResults: function () { return "No results found"; }, searching: function () { return "Searching…"; }, removeAllItems: function () { return "Remove all items"; } }, minimumInputLength: 2, placeholder: this.authenticated() ? t.t("person-select.placeholder") : t.t("person-select.login-required"), dropdownParent: this.$("#person-select-dropdown"), ajax: { delay: 500, url: o, contentType: "application/ld+json", beforeSend: function (e) { e.setRequestHeader("Authorization", "Bearer " + s.auth.token), s.isSearching = !0; }, data: e => this.buildUrlData(this, e), processResults: function (e) { s.$("#person-select-dropdown").addClass("select2-bug"), s.lastResult = e; let t = e["hydra:member"]; const i = []; return t.forEach(e => { i.push({ id: e["@id"], text: s.formatPerson(s, e) }); }), { results: i }; }, error: (e, t, i) => { this.handleXhrError(e, t, i); }, complete: (e, t) => { s.isSearching = !1; } } }).on("select2:select", function (e) { s.$("#person-select-dropdown").removeClass("select2-bug"); const t = e.params.data.id; s.object = ((e, t, i = "@id") => { const s = t["hydra:member"]; if (void 0 !== s) for (const _t of s) if (_t[i] === e) return _t; })(t, s.lastResult), n.attr("data-object", JSON.stringify(s.object)), n.data("object", s.object), n.attr("value") !== t && (s.ignoreValueUpdate = !0, n.attr("value", t), s.dispatchEvent(new CustomEvent("change", { detail: { value: t }, bubbles: !0 }))); }).on("select2:closing", e => { s.isSearching && e.preventDefault(); }), !e && "" !== this.value && this.authenticated()) { let _e2 = b(this.entryPointUrl, this.value), _t2 = new URLSearchParams(this.buildUrlData(this, { term: "" })).toString(); _t2 && (_e2 += `?${_t2}`), fetch(_e2, { headers: { "Content-Type": "application/ld+json", Authorization: "Bearer " + this.auth.token } }).then(e => { if (!e.ok) throw e; return e.json(); }).then(e => { s.object = e; const t = e["@id"], i = new Option(s.formatPerson(this, e), t, !0, !0); n.attr("data-object", JSON.stringify(e)), n.data("object", e), s.$select.append(i).trigger("change"), s.dispatchEvent(new CustomEvent("change", { detail: { value: t }, bubbles: !0 })); }).catch(e => { console.log(e), s.clear(); }); } return !0; } buildUrlData(e, t) { return { search: t.term.trim() }; } formatPerson(e, t) { var _t$givenName; let i = (_t$givenName = t.givenName) != null ? _t$givenName : ""; return t.familyName && (i += ` ${t.familyName}`), i; } update(e) { e.forEach((e, t) => { switch (t) { case "lang": this._i18n.changeLanguage(this.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(); } }), super.update(e); } select2IsInitialized() { return null !== this.$select && this.$select.hasClass("select2-hidden-accessible"); } reloadClick() { null !== this.object && this.dispatchEvent(new CustomEvent("change", { detail: { value: this.value }, bubbles: !0 })); } authenticated() { return "" !== (this.auth.token || ""); } static get styles() { return [l(), c(), h(), u(), d(), g(_t3 || (_t3 = _` #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() { const e = this._i18n, t = p(s); return m(_t4 || (_t4 = _` <link rel="stylesheet" href="${0}" /> <style> #${0} { width: 100%; } </style> <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} @click="${0}" style="display: ${0}" title="${0}"> <dbp-icon name="reload"></dbp-icon> </a> </div> <div id="person-select-dropdown"></div> </div> `), t, this.selectId, this.selectId, !this.active || this.disabled, this.authenticated() ? "" : m(_t5 || (_t5 = _` <option value="" disabled selected> ${0} </option> `), e.t("person-select.login-required")), null === this.object, this.reloadClick, this.showReloadButton ? "flex" : "none", this.reloadButtonTitle); } } class E extends o(w) { buildUrlData(e, t) { let i = t.term.trim(), s = { includeLocal: "email" }; return s.search = i, s; } formatPerson(e, t) { var _t$givenName2; let i = (_t$givenName2 = t.givenName) != null ? _t$givenName2 : ""; t.familyName && (i += ` ${t.familyName}`); let s = t.localData.email; return null !== s && s.length && (i += ` (${s})`), i; } } export { E as C }; //# sourceMappingURL=custom-person-select.BzZGLcwb.es.js.map