@teipublisher/pb-components 2.26.0-next-3.12 → 2.26.0-next-3.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. package/.github/workflows/main.yml +3 -3
  2. package/.github/workflows/node.js.yml +3 -3
  3. package/.github/workflows/release.js.yml +3 -3
  4. package/CHANGELOG.md +30 -0
  5. package/Dockerfile +78 -70
  6. package/css/components.css +5 -5
  7. package/dist/demo/pb-drawer2.html +1 -1
  8. package/dist/demo/pb-leaflet-map.html +1 -1
  9. package/dist/demo/pb-progress.html +2 -2
  10. package/dist/demo/pb-repeat.html +1 -3
  11. package/dist/demo/pb-view3.html +1 -1
  12. package/dist/{paper-icon-button-0fb125c4.js → paper-icon-button-72125e67.js} +1 -1
  13. package/dist/pb-code-editor.js +25 -20
  14. package/dist/pb-component-docs.js +58 -54
  15. package/dist/pb-components-bundle.js +1937 -1782
  16. package/dist/pb-edit-app.js +167 -107
  17. package/dist/pb-elements.json +45 -45
  18. package/dist/{pb-i18n-0611135a.js → pb-i18n-4cc00bfe.js} +1 -1
  19. package/dist/pb-leaflet-map.js +23 -23
  20. package/dist/pb-mei.js +56 -41
  21. package/dist/{pb-mixin-b1caa22e.js → pb-mixin-886ece32.js} +1 -1
  22. package/dist/pb-odd-editor.js +923 -756
  23. package/dist/pb-tify.js +2 -2
  24. package/dist/{vaadin-element-mixin-49ab4037.js → vaadin-element-mixin-84fb7d82.js} +178 -163
  25. package/gh-pages.js +5 -3
  26. package/i18n/common/pl.json +2 -2
  27. package/lib/openseadragon.min.js +1 -1
  28. package/package.json +2 -2
  29. package/pb-elements.json +45 -45
  30. package/src/assets/components.css +5 -5
  31. package/src/authority/airtable.js +20 -21
  32. package/src/authority/anton.js +129 -129
  33. package/src/authority/custom.js +23 -21
  34. package/src/authority/geonames.js +38 -32
  35. package/src/authority/gnd.js +47 -42
  36. package/src/authority/kbga.js +137 -134
  37. package/src/authority/metagrid.js +44 -46
  38. package/src/authority/reconciliation.js +66 -67
  39. package/src/authority/registry.js +4 -4
  40. package/src/docs/pb-component-docs.js +2 -2
  41. package/src/docs/pb-component-view.js +5 -5
  42. package/src/docs/pb-components-list.js +2 -2
  43. package/src/docs/pb-demo-snippet.js +2 -2
  44. package/src/dts-client.js +299 -297
  45. package/src/dts-select-endpoint.js +90 -82
  46. package/src/parse-date-service.js +184 -135
  47. package/src/pb-ajax.js +150 -146
  48. package/src/pb-authority-lookup.js +183 -146
  49. package/src/pb-autocomplete.js +292 -280
  50. package/src/pb-blacklab-highlight.js +264 -259
  51. package/src/pb-blacklab-results.js +236 -221
  52. package/src/pb-browse-docs.js +540 -475
  53. package/src/pb-browse.js +68 -65
  54. package/src/pb-clipboard.js +79 -76
  55. package/src/pb-code-editor.js +110 -102
  56. package/src/pb-code-highlight.js +209 -204
  57. package/src/pb-codepen.js +79 -72
  58. package/src/pb-collapse.js +212 -207
  59. package/src/pb-combo-box.js +190 -190
  60. package/src/pb-components-bundle.js +1 -1
  61. package/src/pb-custom-form.js +151 -149
  62. package/src/pb-dialog.js +94 -85
  63. package/src/pb-document.js +89 -90
  64. package/src/pb-download.js +210 -198
  65. package/src/pb-drawer.js +145 -148
  66. package/src/pb-edit-app.js +301 -229
  67. package/src/pb-edit-xml.js +98 -96
  68. package/src/pb-events.js +114 -107
  69. package/src/pb-facs-link.js +104 -102
  70. package/src/pb-facsimile.js +411 -413
  71. package/src/pb-formula.js +151 -153
  72. package/src/pb-geolocation.js +129 -131
  73. package/src/pb-grid-action.js +53 -56
  74. package/src/pb-grid.js +231 -228
  75. package/src/pb-highlight.js +140 -140
  76. package/src/pb-hotkeys.js +40 -42
  77. package/src/pb-i18n.js +101 -104
  78. package/src/pb-image-strip.js +84 -78
  79. package/src/pb-lang.js +132 -128
  80. package/src/pb-leaflet-map.js +488 -485
  81. package/src/pb-link.js +126 -124
  82. package/src/pb-load.js +431 -426
  83. package/src/pb-login.js +291 -248
  84. package/src/pb-manage-odds.js +364 -318
  85. package/src/pb-map-icon.js +89 -89
  86. package/src/pb-map-layer.js +85 -85
  87. package/src/pb-markdown.js +90 -99
  88. package/src/pb-media-query.js +74 -72
  89. package/src/pb-mei.js +306 -295
  90. package/src/pb-message.js +144 -144
  91. package/src/pb-mixin.js +269 -264
  92. package/src/pb-navigation.js +80 -82
  93. package/src/pb-observable.js +38 -38
  94. package/src/pb-odd-editor.js +1053 -955
  95. package/src/pb-odd-elementspec-editor.js +348 -297
  96. package/src/pb-odd-model-editor.js +1061 -901
  97. package/src/pb-odd-parameter-editor.js +200 -178
  98. package/src/pb-odd-rendition-editor.js +136 -124
  99. package/src/pb-page.js +431 -421
  100. package/src/pb-paginate.js +202 -190
  101. package/src/pb-panel.js +191 -179
  102. package/src/pb-popover-themes.js +7 -5
  103. package/src/pb-popover.js +296 -287
  104. package/src/pb-print-preview.js +127 -127
  105. package/src/pb-progress.js +51 -51
  106. package/src/pb-repeat.js +105 -104
  107. package/src/pb-restricted.js +84 -77
  108. package/src/pb-search.js +252 -241
  109. package/src/pb-select-feature.js +127 -120
  110. package/src/pb-select-odd.js +132 -124
  111. package/src/pb-select-template.js +89 -78
  112. package/src/pb-select.js +251 -227
  113. package/src/pb-split-list.js +179 -174
  114. package/src/pb-svg.js +80 -79
  115. package/src/pb-table-column.js +54 -54
  116. package/src/pb-table-grid.js +221 -203
  117. package/src/pb-tabs.js +61 -63
  118. package/src/pb-tify.js +154 -154
  119. package/src/pb-timeline.js +271 -229
  120. package/src/pb-toggle-feature.js +182 -175
  121. package/src/pb-upload.js +184 -174
  122. package/src/pb-version.js +30 -30
  123. package/src/pb-view-annotate.js +132 -98
  124. package/src/pb-view.js +1289 -1270
  125. package/src/pb-zoom.js +75 -59
  126. package/src/polymer-hack.js +1 -1
  127. package/src/search-result-service.js +256 -223
  128. package/src/seed-element.js +13 -20
  129. package/src/settings.js +4 -4
  130. package/src/theming.js +96 -96
  131. package/src/urls.js +289 -289
  132. package/src/utils.js +53 -51
@@ -2,7 +2,6 @@ import { LitElement, html, css } from 'lit-element';
2
2
  import { pbMixin, waitOnce } from './pb-mixin.js';
3
3
  import { themableMixin } from './theming.js';
4
4
 
5
-
6
5
  /**
7
6
  * Open eXide to edit a given source document.
8
7
  *
@@ -10,109 +9,112 @@ import { themableMixin } from './theming.js';
10
9
  * @slot - unnamed slot for the link text when eXide tab is already opened
11
10
  */
12
11
  export class PbEditXml extends themableMixin(pbMixin(LitElement)) {
13
-
14
- static get properties() {
15
- return {
16
- ...super.properties,
17
- /**
18
- * expects a context-absolute path to the document to edit e.g. '/db/apps/tei-publisher/mytext.xml'
19
- */
20
- path: {
21
- type: String
22
- },
23
- /**
24
- * optional id reference to a pb-document
25
- */
26
- src: {
27
- type: String
28
- },
29
- /**
30
- * HTML title to be used
31
- */
32
- title: {
33
- type: String
34
- },
35
- _href: {
36
- type: String
37
- }
38
- };
39
- }
12
+ static get properties() {
13
+ return {
14
+ ...super.properties,
15
+ /**
16
+ * expects a context-absolute path to the document to edit e.g. '/db/apps/tei-publisher/mytext.xml'
17
+ */
18
+ path: {
19
+ type: String,
20
+ },
21
+ /**
22
+ * optional id reference to a pb-document
23
+ */
24
+ src: {
25
+ type: String,
26
+ },
27
+ /**
28
+ * HTML title to be used
29
+ */
30
+ title: {
31
+ type: String,
32
+ },
33
+ _href: {
34
+ type: String,
35
+ },
36
+ };
37
+ }
40
38
 
41
- constructor() {
42
- super();
43
- this.title = '';
44
- }
39
+ constructor() {
40
+ super();
41
+ this.title = '';
42
+ }
45
43
 
46
- connectedCallback() {
47
- super.connectedCallback();
48
- waitOnce('pb-page-ready', (options) => {
49
- if (options.endpoint === '.') {
50
- this._href = '/exist/apps/eXide/';
51
- } else {
52
- const host = /^(.*:\/+[^/]+)\/.*$/.exec(options.endpoint);
53
- if (host) {
54
- this._href = `${host[1]}/exist/apps/eXide/`;
55
- } else {
56
- this._href = '/exist/apps/eXide/';
57
- }
58
- }
59
- });
60
- }
61
-
62
- render() {
63
- // if the target is within the same origin as the current page, we can communicate with an
64
- // already opened eXide, if not, only option is to open a new window.
65
- if (new URL(this._href, window.location.href).origin === this.getUrl().origin) {
66
- return html`<a href="${this._href}" target="eXide" title="${this.title}" @click="${this.open}"><slot></slot></a>`;
44
+ connectedCallback() {
45
+ super.connectedCallback();
46
+ waitOnce('pb-page-ready', options => {
47
+ if (options.endpoint === '.') {
48
+ this._href = '/exist/apps/eXide/';
49
+ } else {
50
+ const host = /^(.*:\/+[^/]+)\/.*$/.exec(options.endpoint);
51
+ if (host) {
52
+ this._href = `${host[1]}/exist/apps/eXide/`;
53
+ } else {
54
+ this._href = '/exist/apps/eXide/';
67
55
  }
68
- return html`<a href="${this._href}/index.html?open=${this.path}" title="${this.title}"><slot></slot></a>`;
56
+ }
57
+ });
58
+ }
59
+
60
+ render() {
61
+ // if the target is within the same origin as the current page, we can communicate with an
62
+ // already opened eXide, if not, only option is to open a new window.
63
+ if (new URL(this._href, window.location.href).origin === this.getUrl().origin) {
64
+ return html`<a href="${this._href}" target="eXide" title="${this.title}" @click="${this.open}"
65
+ ><slot></slot
66
+ ></a>`;
69
67
  }
68
+ return html`<a href="${this._href}/index.html?open=${this.path}" title="${this.title}"
69
+ ><slot></slot
70
+ ></a>`;
71
+ }
70
72
 
71
- static get styles() {
72
- return css`
73
- :host {
74
- display: inline;
75
- }
73
+ static get styles() {
74
+ return css`
75
+ :host {
76
+ display: inline;
77
+ }
76
78
 
77
- a {
78
- text-decoration: none;
79
- }
80
- `;
81
- }
79
+ a {
80
+ text-decoration: none;
81
+ }
82
+ `;
83
+ }
82
84
 
83
- setPath(path) {
84
- this.path = path;
85
- }
85
+ setPath(path) {
86
+ this.path = path;
87
+ }
86
88
 
87
- open(ev) {
88
- ev.preventDefault();
89
- let href = this._href;
90
- let path = this.path;
91
- if (this.src) {
92
- const sourceComponent = document.getElementById(this.src);
93
- path = sourceComponent.getFullPath();
94
- href = sourceComponent.sourceView;
95
- }
89
+ open(ev) {
90
+ ev.preventDefault();
91
+ let href = this._href;
92
+ let { path } = this;
93
+ if (this.src) {
94
+ const sourceComponent = document.getElementById(this.src);
95
+ path = sourceComponent.getFullPath();
96
+ href = sourceComponent.sourceView;
97
+ }
96
98
 
97
- // try to retrieve existing eXide window
98
- const exide = window.open("", "eXide");
99
- if (exide && !exide.closed) {
100
- // check if eXide is really available or it's an empty page
101
- const app = exide.eXide;
102
- if (app) {
103
- console.log("<pb-edit-xml> using existing eXide to open %s", path);
104
- // eXide is there
105
- exide.eXide.app.findDocument(path);
106
- exide.focus();
107
- } else {
108
- console.log("<pb-edit-xml> opening new eXide for %s", path);
109
- window.eXide_onload = function () {
110
- exide.eXide.app.findDocument(path);
111
- };
112
- // empty page
113
- exide.location = href;
114
- }
115
- }
99
+ // try to retrieve existing eXide window
100
+ const exide = window.open('', 'eXide');
101
+ if (exide && !exide.closed) {
102
+ // check if eXide is really available or it's an empty page
103
+ const app = exide.eXide;
104
+ if (app) {
105
+ console.log('<pb-edit-xml> using existing eXide to open %s', path);
106
+ // eXide is there
107
+ exide.eXide.app.findDocument(path);
108
+ exide.focus();
109
+ } else {
110
+ console.log('<pb-edit-xml> opening new eXide for %s', path);
111
+ window.eXide_onload = function () {
112
+ exide.eXide.app.findDocument(path);
113
+ };
114
+ // empty page
115
+ exide.location = href;
116
+ }
116
117
  }
118
+ }
117
119
  }
118
- customElements.define('pb-edit-xml', PbEditXml);
120
+ customElements.define('pb-edit-xml', PbEditXml);
package/src/pb-events.js CHANGED
@@ -1,123 +1,130 @@
1
- import { defaultChannel } from "./pb-mixin.js";
1
+ import { defaultChannel } from './pb-mixin.js';
2
2
 
3
3
  /**
4
4
  * Utility class to plug into TEI Publisher's event system from custom javascript.
5
5
  */
6
6
  export class PbEvents {
7
+ /**
8
+ * Subscribe to an event received on particular channels.
9
+ *
10
+ * @param {string} name the name of the event to listen for
11
+ * @param {string|string[]|null} channels name of a channel, array of channel names or null to target the default channel
12
+ * @param {Function|undefined} callback function called when event is triggered.
13
+ * Receives the event as first and the event handler as second parameter.
14
+ */
15
+ static subscribe(name, channels, callback, once = false) {
16
+ const _channels = PbEvents._getChannels(channels);
17
+ const handler = document.addEventListener(
18
+ name,
19
+ (/** @type {CustomEvent} */ ev) => {
20
+ if (callback && ev.detail && ev.detail.key && _channels.includes(ev.detail.key)) {
21
+ callback(ev, handler);
22
+ }
23
+ },
24
+ {
25
+ once,
26
+ },
27
+ );
28
+ }
7
29
 
8
- /**
9
- * Subscribe to an event received on particular channels.
10
- *
11
- * @param {string} name the name of the event to listen for
12
- * @param {string|string[]|null} channels name of a channel, array of channel names or null to target the default channel
13
- * @param {Function|undefined} callback function called when event is triggered.
14
- * Receives the event as first and the event handler as second parameter.
15
- */
16
- static subscribe(name, channels, callback, once=false) {
17
- const _channels = PbEvents._getChannels(channels)
18
- const handler = document.addEventListener(name, (/** @type {CustomEvent} */ ev) => {
19
- if (callback && ev.detail && ev.detail.key && _channels.includes(ev.detail.key)) {
20
- callback(ev, handler);
21
- }
22
- }, {
23
- once
24
- });
25
- }
30
+ /**
31
+ * Subscribe to an event received on a particular channel once. Returns a promise
32
+ * which resolves when the event is caught.
33
+ *
34
+ * @param {string} name the name of the event to listen for
35
+ * @param {string|string[]|null} channels name of a channel, array of channel names or null to target the default channel
36
+ * @returns {Promise} resolves if event is caught, providing the event as parameter
37
+ */
38
+ static subscribeOnce(name, channels = null) {
39
+ const _channels = PbEvents._getChannels(channels);
40
+ return new Promise(resolve => {
41
+ document.addEventListener(
42
+ name,
43
+ (/** @type {CustomEvent} */ ev) => {
44
+ if (ev.detail && ev.detail.key && _channels.includes(ev.detail.key)) {
45
+ resolve(ev);
46
+ }
47
+ },
48
+ {
49
+ once: true,
50
+ },
51
+ );
52
+ });
53
+ }
26
54
 
27
- /**
28
- * Subscribe to an event received on a particular channel once. Returns a promise
29
- * which resolves when the event is caught.
30
- *
31
- * @param {string} name the name of the event to listen for
32
- * @param {string|string[]|null} channels name of a channel, array of channel names or null to target the default channel
33
- * @returns {Promise} resolves if event is caught, providing the event as parameter
34
- */
35
- static subscribeOnce(name, channels=null) {
36
- const _channels = PbEvents._getChannels(channels);
37
- return new Promise((resolve) => {
38
- document.addEventListener(name, (/** @type {CustomEvent} */ ev) => {
39
- if (ev.detail && ev.detail.key && _channels.includes(ev.detail.key)) {
40
- resolve(ev);
41
- }
42
- }, {
43
- once: true
44
- });
45
- });
55
+ /**
56
+ * determine channels to subscribe to
57
+ *
58
+ * @param {string|string[]|null} channels name of a channel, array of channel names or null to target the default channel
59
+ * @returns {string[]} channels
60
+ */
61
+ static _getChannels(channels) {
62
+ // no channels: null or empty string or empty array
63
+ if (channels === null || !channels.length) {
64
+ return [defaultChannel];
46
65
  }
47
-
48
- /**
49
- * determine channels to subscribe to
50
- *
51
- * @param {string|string[]|null} channels name of a channel, array of channel names or null to target the default channel
52
- * @returns {string[]} channels
53
- */
54
- static _getChannels(channels) {
55
- // no channels: null or empty string or empty array
56
- if (channels === null || !channels.length) {
57
- return [defaultChannel]
58
- }
59
- // single string
60
- if (!Array.isArray(channels)) {
61
- return [channels];
62
- }
63
- return channels;
66
+ // single string
67
+ if (!Array.isArray(channels)) {
68
+ return [channels];
64
69
  }
70
+ return channels;
71
+ }
65
72
 
66
- /**
67
- * Emit an event to a particular channel
68
- *
69
- * @param {string} type the name of the event to emit
70
- * @param {string|null} channel name of the channel or null to target the default channel
71
- * @param {any|null} detail value to pass in the event details
72
- */
73
- static emit(type, channel=null, detail=null) {
74
- const options = detail || {};
75
- options.key = channel || defaultChannel;
76
- const ev = new CustomEvent(type, {
77
- detail: options
78
- });
79
- document.dispatchEvent(ev);
80
- }
73
+ /**
74
+ * Emit an event to a particular channel
75
+ *
76
+ * @param {string} type the name of the event to emit
77
+ * @param {string|null} channel name of the channel or null to target the default channel
78
+ * @param {any|null} detail value to pass in the event details
79
+ */
80
+ static emit(type, channel = null, detail = null) {
81
+ const options = detail || {};
82
+ options.key = channel || defaultChannel;
83
+ const ev = new CustomEvent(type, {
84
+ detail: options,
85
+ });
86
+ document.dispatchEvent(ev);
87
+ }
81
88
 
82
- /**
83
- * Wait for one or more TEI Publisher web components to become ready (by waiting for their `pb-ready` event).
84
- *
85
- * @param {HTMLElement|HTMLElement[]} targets element or array of elements to check for ready state
86
- * @returns Promise which resolves when all components are ready
87
- */
88
- static ifReady(targets) {
89
- if (!Array.isArray(targets)) {
90
- targets = [targets];
89
+ /**
90
+ * Wait for one or more TEI Publisher web components to become ready (by waiting for their `pb-ready` event).
91
+ *
92
+ * @param {HTMLElement|HTMLElement[]} targets element or array of elements to check for ready state
93
+ * @returns Promise which resolves when all components are ready
94
+ */
95
+ static ifReady(targets) {
96
+ if (!Array.isArray(targets)) {
97
+ targets = [targets];
98
+ }
99
+ // const targets = Array.from(document.querySelectorAll(selector));
100
+ return new Promise(resolve => {
101
+ const targetCount = targets.length;
102
+ if (targetCount === 0) {
103
+ // selector did not return any targets
104
+ resolve();
105
+ return;
106
+ }
107
+ let count = targetCount;
108
+ targets.forEach(target => {
109
+ if (target._isReady) {
110
+ count -= 1;
111
+ if (count === 0) {
112
+ resolve();
113
+ }
114
+ return;
91
115
  }
92
- // const targets = Array.from(document.querySelectorAll(selector));
93
- return new Promise((resolve) => {
94
- const targetCount = targets.length;
95
- if (targetCount === 0) {
96
- // selector did not return any targets
97
- resolve();
98
- return;
99
- }
100
- let count = targetCount;
101
- targets.forEach((target) => {
102
- if (target._isReady) {
103
- count -= 1;
104
- if (count === 0) {
105
- resolve();
106
- }
107
- return;
108
- }
109
- const handler = target.addEventListener('pb-ready', () => {
110
- count -= 1;
111
- if (count === 0) {
112
- target.removeEventListener('pb-ready', handler);
113
- resolve();
114
- }
115
- });
116
- });
116
+ const handler = target.addEventListener('pb-ready', () => {
117
+ count -= 1;
118
+ if (count === 0) {
119
+ target.removeEventListener('pb-ready', handler);
120
+ resolve();
121
+ }
117
122
  });
118
- }
123
+ });
124
+ });
125
+ }
119
126
  }
120
127
 
121
128
  if (!window.pbEvents) {
122
- window.pbEvents = PbEvents;
123
- }
129
+ window.pbEvents = PbEvents;
130
+ }