UNPKG

@dbp-topics/sublibrary

Version:

[GitLab Repository](https://github.com/digital-blueprint/sublibrary-app) | [npmjs package](https://www.npmjs.com/package/@dbp-topics/sublibrary) | [Unpkg CDN](https://unpkg.com/browse/@dbp-topics/sublibrary/) | [Sublibrary Bundle](https://gitlab.tugraz.at

383 lines (377 loc) 24.6 kB
let _ = t => t, _t2, _t3, _t4; function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } /*! * License: LGPL-2.1-or-later * Dependencies: * * @dbp-toolkit/common: LGPL-2.1-or-later * jquery: MIT * select2: MIT * @dbp-toolkit/resource-select: LGPL-2.1-or-later * @babel/runtime: MIT * i18next: MIT * @lit/reactive-element: BSD-3-Clause * lit-html: BSD-3-Clause * lit-element: BSD-3-Clause * @open-wc/dedupe-mixin: MIT * @open-wc/scoped-elements: MIT * datatables.net: MIT * datatables.net-responsive: MIT * datatables.net-responsive-dt: MIT * datatables.net-dt: MIT * jszip: (MIT OR GPL-3.0-or-later) * datatables.net-buttons-dt: MIT * datatables.net-buttons: MIT * @dbp-toolkit/data-table-view: LGPL-2.1-or-later * @dbp-toolkit/person-select: LGPL-2.1-or-later */ import { s as e, j as t, e as i, b as s } from "./library-select.cb305ad9.es.js"; import { J as n } from "./jsonld.3c83677b.es.js"; import { f as o, S as a, A as r, m as A, I as l, q as c, g as h, a as u, l as d, t as g, c as p, i as m, d as B, y as b } from "./_commonjsHelpers.01af1198.es.js"; var w = { "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" } }; const E = { "@id": "@id", givenName: "http://schema.org/givenName", familyName: "http://schema.org/familyName", email: "http://schema.org/email" }; e(window, t); class Q extends a(r) { constructor() { super(), Object.assign(Q.prototype, i), this.auth = {}, this._i18n = o({ en: C, de: w }, "de", "en"), this.lang = this._i18n.language, this.entryPointUrl = "", this.jsonld = 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.showDetails = !1, this._onDocumentClicked = this._onDocumentClicked.bind(this); } static get scopedElements() { return { "dbp-icon": l }; } $(e) { return t(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" }, showDetails: { type: Boolean, attribute: "show-details" }, auth: { type: Object } }); } clear() { this.object = null, t(this).attr("data-object", ""), t(this).data("object", null), this.value = "", t(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.initJSONLD(); }); } 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) && _e.select2("close"); } } initJSONLD(e = !1) { const t = this; n.getInstance(this.entryPointUrl).then(function (i) { t.jsonld = i, t.active = t.authenticated(), c(() => t.initSelect2(e), 1e4, 100); }, {}, this.lang); } initSelect2(e = !1) { const i = this._i18n, s = this, n = t(this); if (null === this.jsonld) return !1; const o = this.jsonld.getApiUrlForEntityName("BasePerson"); if (null === this.$select) return !1; 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() ? i.t("person-select.placeholder") : i.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: function (e) { return { search: e.term.trim() }; }, processResults: function (e) { s.$("#person-select-dropdown").addClass("select2-bug"), s.lastResult = e; let t = s.jsonld.transformMembers(e, E); const i = []; return t.forEach(e => { i.push({ id: e["@id"], text: s.generateOptionText(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) { const _e2 = this.entryPointUrl + this.value; 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 = s.jsonld.compactMember(s.jsonld.expandMember(e), E), i = t["@id"], o = new Option(s.generateOptionText(t), i, !0, !0); n.attr("data-object", JSON.stringify(e)), n.data("object", e), s.$select.append(o).trigger("change"), s.dispatchEvent(new CustomEvent("change", { detail: { value: i }, bubbles: !0 })); }).catch(e => { console.log(e), s.clear(); }); } return !0; } generateOptionText(e) { var _e$givenName; let t = (_e$givenName = e.givenName) != null ? _e$givenName : ""; return e.familyName && (t += ` ${e.familyName}`), this.showDetails && void 0 !== e.email && null !== e.email && (t += ` (${e.email})`), t; } 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.initJSONLD(!0); break; case "auth": this.active = this.authenticated(); } }), 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 [h(), u(), d(), g(), p(), m(_t2 || (_t2 = _` .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 = B(s); return b(_t3 || (_t3 = _` <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.authenticated() ? "" : b(_t4 || (_t4 = _` <option value="" disabled selected> ${0} </option> `), e.t("person-select.login-required")), null === this.object, this.reloadClick, this.showReloadButton ? "flex" : "none", this.reloadButtonTitle); } } export { Q as P }; //# sourceMappingURL=person-select.503b43f7.es.js.map