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

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 (136) 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 +43 -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-grid.html +19 -6
  9. package/dist/demo/pb-leaflet-map.html +1 -1
  10. package/dist/demo/pb-progress.html +2 -2
  11. package/dist/demo/pb-repeat.html +1 -3
  12. package/dist/demo/pb-view3.html +1 -1
  13. package/dist/{iron-form-277f9d42.js → iron-form-78b43d38.js} +1 -1
  14. package/dist/{paper-checkbox-4f410b1f.js → paper-checkbox-d16f23be.js} +44 -44
  15. package/dist/{paper-icon-button-0fb125c4.js → paper-icon-button-2cd9e0b4.js} +3 -3
  16. package/dist/{paper-listbox-c2468542.js → paper-listbox-2ad5c882.js} +7 -7
  17. package/dist/pb-code-editor.js +25 -20
  18. package/dist/pb-component-docs.js +58 -54
  19. package/dist/pb-components-bundle.js +2057 -2351
  20. package/dist/pb-edit-app.js +167 -107
  21. package/dist/pb-elements.json +45 -45
  22. package/dist/{pb-i18n-0611135a.js → pb-i18n-4cc00bfe.js} +1 -1
  23. package/dist/pb-leaflet-map.js +23 -23
  24. package/dist/pb-mei.js +56 -41
  25. package/dist/{pb-mixin-b1caa22e.js → pb-mixin-886ece32.js} +1 -1
  26. package/dist/pb-odd-editor.js +923 -756
  27. package/dist/pb-tify.js +2 -2
  28. package/dist/{vaadin-element-mixin-49ab4037.js → vaadin-element-mixin-c200b196.js} +179 -164
  29. package/gh-pages.js +5 -3
  30. package/i18n/common/pl.json +2 -2
  31. package/lib/openseadragon.min.js +1 -1
  32. package/package.json +2 -2
  33. package/pb-elements.json +45 -45
  34. package/src/assets/components.css +5 -5
  35. package/src/authority/airtable.js +20 -21
  36. package/src/authority/anton.js +129 -129
  37. package/src/authority/custom.js +23 -21
  38. package/src/authority/geonames.js +38 -32
  39. package/src/authority/gnd.js +47 -42
  40. package/src/authority/kbga.js +137 -134
  41. package/src/authority/metagrid.js +44 -46
  42. package/src/authority/reconciliation.js +66 -67
  43. package/src/authority/registry.js +4 -4
  44. package/src/docs/pb-component-docs.js +2 -2
  45. package/src/docs/pb-component-view.js +5 -5
  46. package/src/docs/pb-components-list.js +2 -2
  47. package/src/docs/pb-demo-snippet.js +2 -2
  48. package/src/dts-client.js +299 -297
  49. package/src/dts-select-endpoint.js +90 -82
  50. package/src/parse-date-service.js +184 -135
  51. package/src/pb-ajax.js +150 -146
  52. package/src/pb-authority-lookup.js +183 -146
  53. package/src/pb-autocomplete.js +292 -280
  54. package/src/pb-blacklab-highlight.js +264 -259
  55. package/src/pb-blacklab-results.js +236 -221
  56. package/src/pb-browse-docs.js +540 -475
  57. package/src/pb-browse.js +68 -65
  58. package/src/pb-clipboard.js +79 -76
  59. package/src/pb-code-editor.js +110 -102
  60. package/src/pb-code-highlight.js +209 -204
  61. package/src/pb-codepen.js +79 -72
  62. package/src/pb-collapse.js +212 -207
  63. package/src/pb-combo-box.js +190 -190
  64. package/src/pb-components-bundle.js +1 -1
  65. package/src/pb-custom-form.js +151 -149
  66. package/src/pb-dialog.js +94 -85
  67. package/src/pb-document.js +89 -90
  68. package/src/pb-download.js +210 -198
  69. package/src/pb-drawer.js +145 -148
  70. package/src/pb-edit-app.js +301 -229
  71. package/src/pb-edit-xml.js +98 -96
  72. package/src/pb-events.js +114 -107
  73. package/src/pb-facs-link.js +104 -102
  74. package/src/pb-facsimile.js +419 -414
  75. package/src/pb-formula.js +151 -153
  76. package/src/pb-geolocation.js +129 -131
  77. package/src/pb-grid-action.js +53 -56
  78. package/src/pb-grid.js +231 -228
  79. package/src/pb-highlight.js +140 -140
  80. package/src/pb-hotkeys.js +40 -42
  81. package/src/pb-i18n.js +101 -104
  82. package/src/pb-image-strip.js +84 -78
  83. package/src/pb-lang.js +132 -128
  84. package/src/pb-leaflet-map.js +488 -485
  85. package/src/pb-link.js +126 -124
  86. package/src/pb-load.js +431 -426
  87. package/src/pb-login.js +291 -248
  88. package/src/pb-manage-odds.js +364 -318
  89. package/src/pb-map-icon.js +89 -89
  90. package/src/pb-map-layer.js +85 -85
  91. package/src/pb-markdown.js +90 -99
  92. package/src/pb-media-query.js +74 -72
  93. package/src/pb-mei.js +306 -295
  94. package/src/pb-message.js +144 -144
  95. package/src/pb-mixin.js +269 -264
  96. package/src/pb-navigation.js +80 -82
  97. package/src/pb-observable.js +38 -38
  98. package/src/pb-odd-editor.js +1053 -955
  99. package/src/pb-odd-elementspec-editor.js +348 -297
  100. package/src/pb-odd-model-editor.js +1061 -901
  101. package/src/pb-odd-parameter-editor.js +200 -178
  102. package/src/pb-odd-rendition-editor.js +136 -124
  103. package/src/pb-page.js +431 -421
  104. package/src/pb-paginate.js +202 -190
  105. package/src/pb-panel.js +198 -182
  106. package/src/pb-popover-themes.js +7 -5
  107. package/src/pb-popover.js +296 -287
  108. package/src/pb-print-preview.js +127 -127
  109. package/src/pb-progress.js +51 -51
  110. package/src/pb-repeat.js +105 -104
  111. package/src/pb-restricted.js +84 -77
  112. package/src/pb-search.js +252 -241
  113. package/src/pb-select-feature.js +127 -120
  114. package/src/pb-select-odd.js +132 -124
  115. package/src/pb-select-template.js +89 -78
  116. package/src/pb-select.js +251 -227
  117. package/src/pb-split-list.js +179 -174
  118. package/src/pb-svg.js +80 -79
  119. package/src/pb-table-column.js +54 -54
  120. package/src/pb-table-grid.js +221 -203
  121. package/src/pb-tabs.js +61 -63
  122. package/src/pb-tify.js +154 -154
  123. package/src/pb-timeline.js +271 -229
  124. package/src/pb-toggle-feature.js +182 -175
  125. package/src/pb-upload.js +184 -174
  126. package/src/pb-version.js +30 -30
  127. package/src/pb-view-annotate.js +132 -98
  128. package/src/pb-view.js +1290 -1270
  129. package/src/pb-zoom.js +75 -59
  130. package/src/polymer-hack.js +1 -1
  131. package/src/search-result-service.js +256 -223
  132. package/src/seed-element.js +13 -20
  133. package/src/settings.js +4 -4
  134. package/src/theming.js +96 -96
  135. package/src/urls.js +289 -289
  136. package/src/utils.js +53 -51
package/src/pb-ajax.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { LitElement, html, css } from 'lit-element';
2
2
  import '@polymer/iron-ajax';
3
3
  import { pbMixin } from './pb-mixin.js';
4
- import { get as i18n } from "./pb-i18n.js";
4
+ import { get as i18n } from './pb-i18n.js';
5
5
  import './pb-message.js';
6
6
 
7
7
  /**
@@ -21,165 +21,169 @@ import './pb-message.js';
21
21
 
22
22
  */
23
23
  export class PbAjax extends pbMixin(LitElement) {
24
- static get properties() {
25
- return {
26
- ...super.properties,
27
- /**
28
- * the URL to send a request to
29
- */
30
- url: {
31
- type: String
32
- },
33
- /**
34
- * Title of link that triggers the request
35
- */
36
- title: {
37
- type: String
38
- },
39
- /**
40
- * HTTP method to use, e.g. 'get', 'post', 'delete' ...
41
- */
42
- method: {
43
- type: String
44
- },
45
- /**
46
- * If set, emits an event with the given name to the channel
47
- * this component is subscribed to.
48
- */
49
- event: {
50
- type: String
51
- },
52
- /**
53
- * If set, display a confirmation dialog with the message text given in
54
- * this property. The user may cancel the action.
55
- */
56
- confirm: {
57
- type: String
58
- },
59
- /**
60
- * Set to not show the server's response
61
- */
62
- quiet: {
63
- type: Boolean
64
- },
65
- _message: {
66
- type: String
67
- }
68
- };
69
- }
24
+ static get properties() {
25
+ return {
26
+ ...super.properties,
27
+ /**
28
+ * the URL to send a request to
29
+ */
30
+ url: {
31
+ type: String,
32
+ },
33
+ /**
34
+ * Title of link that triggers the request
35
+ */
36
+ title: {
37
+ type: String,
38
+ },
39
+ /**
40
+ * HTTP method to use, e.g. 'get', 'post', 'delete' ...
41
+ */
42
+ method: {
43
+ type: String,
44
+ },
45
+ /**
46
+ * If set, emits an event with the given name to the channel
47
+ * this component is subscribed to.
48
+ */
49
+ event: {
50
+ type: String,
51
+ },
52
+ /**
53
+ * If set, display a confirmation dialog with the message text given in
54
+ * this property. The user may cancel the action.
55
+ */
56
+ confirm: {
57
+ type: String,
58
+ },
59
+ /**
60
+ * Set to not show the server's response
61
+ */
62
+ quiet: {
63
+ type: Boolean,
64
+ },
65
+ _message: {
66
+ type: String,
67
+ },
68
+ };
69
+ }
70
70
 
71
- constructor() {
72
- super();
73
- this.method = 'get';
74
- this.confirm = null;
75
- this.quiet = false;
76
- this._running = false;
77
- }
71
+ constructor() {
72
+ super();
73
+ this.method = 'get';
74
+ this.confirm = null;
75
+ this.quiet = false;
76
+ this._running = false;
77
+ }
78
78
 
79
- connectedCallback() {
80
- super.connectedCallback();
81
- this.subscribeTo('pb-update', this._onUpdate.bind(this));
82
- }
79
+ connectedCallback() {
80
+ super.connectedCallback();
81
+ this.subscribeTo('pb-update', this._onUpdate.bind(this));
82
+ }
83
83
 
84
- render() {
85
- return html`
86
- <a id="button" @click="${this._handleClick}" title="${this.title}"><slot></slot></a>
87
- <iron-ajax
88
- id="loadContent"
89
- verbose
90
- handle-as="text"
91
- method="${this.method}"
92
- with-credentials
93
- @error="${this._handleError}"
94
- @response="${this._handleResponse}"></iron-ajax>
95
- <pb-message id="confirmDialog"></pb-message>
96
- <slot name="title" style="display: none"></slot>
97
- `;
98
- }
84
+ render() {
85
+ return html`
86
+ <a id="button" @click="${this._handleClick}" title="${this.title}"><slot></slot></a>
87
+ <iron-ajax
88
+ id="loadContent"
89
+ verbose
90
+ handle-as="text"
91
+ method="${this.method}"
92
+ with-credentials
93
+ @error="${this._handleError}"
94
+ @response="${this._handleResponse}"
95
+ ></iron-ajax>
96
+ <pb-message id="confirmDialog"></pb-message>
97
+ <slot name="title" style="display: none"></slot>
98
+ `;
99
+ }
99
100
 
100
- firstUpdated() {
101
- super.firstUpdated();
102
- const slot = this.shadowRoot.querySelector('slot[name=title]');
103
- this._dialogTitle = '';
104
- slot.assignedNodes().forEach(node => {this._dialogTitle += node.innerHTML});
105
- this.button = this.renderRoot.getElementById('button');
106
- }
101
+ firstUpdated() {
102
+ super.firstUpdated();
103
+ const slot = this.shadowRoot.querySelector('slot[name=title]');
104
+ this._dialogTitle = '';
105
+ slot.assignedNodes().forEach(node => {
106
+ this._dialogTitle += node.innerHTML;
107
+ });
108
+ this.button = this.renderRoot.getElementById('button');
109
+ }
107
110
 
108
- static get styles() {
109
- return css`
110
- :host {
111
- display: block;
112
- }
113
- slot[name="title"] {
114
- margin: 0;
115
- }
116
- pb-message[open] {
117
- display: block;
118
- }
119
- pb-message:not([open]) {
120
- display: none;
121
- }
122
- `;
123
- }
111
+ static get styles() {
112
+ return css`
113
+ :host {
114
+ display: block;
115
+ }
116
+ slot[name='title'] {
117
+ margin: 0;
118
+ }
119
+ pb-message[open] {
120
+ display: block;
121
+ }
122
+ pb-message:not([open]) {
123
+ display: none;
124
+ }
125
+ `;
126
+ }
124
127
 
125
- _handleClick(ev) {
126
- ev.preventDefault();
127
- if (this._running) {
128
- return;
129
- }
130
- this._running = true;
131
- if (this.confirm) {
132
- const dialog = this.shadowRoot.getElementById('confirmDialog');
133
- dialog.confirm(this._dialogTitle, i18n(this.confirm))
134
- .then(() => this.trigger())
135
- .catch(() => console.log('<pb-ajax> Action cancelled'));
136
- } else {
137
- this.trigger();
138
- }
128
+ _handleClick(ev) {
129
+ ev.preventDefault();
130
+ if (this._running) {
131
+ return;
139
132
  }
140
-
141
- async trigger() {
142
- const loader = this.shadowRoot.getElementById('loadContent');
143
- loader.url = `${this.getEndpoint()}/${this.url}`;
144
- this.emitTo('pb-start-update');
145
- await this.shadowRoot.getElementById('loadContent').generateRequest();
133
+ this._running = true;
134
+ if (this.confirm) {
135
+ const dialog = this.shadowRoot.getElementById('confirmDialog');
136
+ dialog
137
+ .confirm(this._dialogTitle, i18n(this.confirm))
138
+ .then(() => this.trigger())
139
+ .catch(() => console.log('<pb-ajax> Action cancelled'));
140
+ } else {
141
+ this.trigger();
146
142
  }
143
+ }
147
144
 
148
- _handleResponse() {
149
- this._running = false;
150
- const resp = this.shadowRoot.getElementById('loadContent').lastResponse;
151
- this._message = resp;
152
- if (!this.quiet) {
153
- const dialog = this.shadowRoot.getElementById('confirmDialog');
154
- dialog.show(this._dialogTitle, this._message);
155
- }
156
-
157
- this.emitTo('pb-end-update');
145
+ async trigger() {
146
+ const loader = this.shadowRoot.getElementById('loadContent');
147
+ loader.url = `${this.getEndpoint()}/${this.url}`;
148
+ this.emitTo('pb-start-update');
149
+ await this.shadowRoot.getElementById('loadContent').generateRequest();
150
+ }
158
151
 
159
- if (this.event) {
160
- this.emitTo(this.event);
161
- }
152
+ _handleResponse() {
153
+ this._running = false;
154
+ const resp = this.shadowRoot.getElementById('loadContent').lastResponse;
155
+ this._message = resp;
156
+ if (!this.quiet) {
157
+ const dialog = this.shadowRoot.getElementById('confirmDialog');
158
+ dialog.show(this._dialogTitle, this._message);
162
159
  }
163
160
 
164
- _handleError() {
165
- this._running = false;
166
- const loader = this.shadowRoot.getElementById('loadContent');
167
- const msg = loader.lastError.response;
168
- const parser = new DOMParser();
169
- const doc = parser.parseFromString(msg, "application/xml");
170
- const node = doc.querySelector('message');
171
- if (node) {
172
- this._message = node.textContent;
173
- } else {
174
- this._message = msg;
175
- }
176
- const dialog = this.shadowRoot.getElementById('confirmDialog');
177
- dialog.show(i18n('dialogs.error'), this._message);
178
- this.emitTo('pb-end-update');
161
+ this.emitTo('pb-end-update');
162
+
163
+ if (this.event) {
164
+ this.emitTo(this.event);
179
165
  }
166
+ }
180
167
 
181
- _onUpdate(ev) {
182
- this.shadowRoot.getElementById('loadContent').params = ev.detail.params;
168
+ _handleError() {
169
+ this._running = false;
170
+ const loader = this.shadowRoot.getElementById('loadContent');
171
+ const msg = loader.lastError.response;
172
+ const parser = new DOMParser();
173
+ const doc = parser.parseFromString(msg, 'application/xml');
174
+ const node = doc.querySelector('message');
175
+ if (node) {
176
+ this._message = node.textContent;
177
+ } else {
178
+ this._message = msg;
183
179
  }
180
+ const dialog = this.shadowRoot.getElementById('confirmDialog');
181
+ dialog.show(i18n('dialogs.error'), this._message);
182
+ this.emitTo('pb-end-update');
183
+ }
184
+
185
+ _onUpdate(ev) {
186
+ this.shadowRoot.getElementById('loadContent').params = ev.detail.params;
187
+ }
184
188
  }
185
189
  customElements.define('pb-ajax', PbAjax);