@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
@@ -1,6 +1,6 @@
1
1
  import { LitElement, html, css } from 'lit-element';
2
2
  import { pbMixin } from './pb-mixin.js';
3
- import { translate } from "./pb-i18n.js";
3
+ import { translate } from './pb-i18n.js';
4
4
 
5
5
  /**
6
6
  * Display a pagination control from which the user can select a page to view
@@ -15,196 +15,208 @@ import { translate } from "./pb-i18n.js";
15
15
  * @csspart count - the span displaying the number of items
16
16
  */
17
17
  export class PbPaginate extends pbMixin(LitElement) {
18
- static get properties() {
19
- return {
20
- ...super.properties,
21
- /**
22
- * total number of pages
23
- */
24
- total: {
25
- type: Number,
26
- reflect: true
27
- },
28
- /**
29
- * start page
30
- */
31
- start: {
32
- type: Number,
33
- reflect: true
34
- },
35
- /**
36
- * amount of entries per page
37
- */
38
- perPage: {
39
- type: Number,
40
- attribute: 'per-page'
41
- },
42
- /**
43
- * i18n key to use for looking up the message showing number of items in list
44
- * or fixed label to display
45
- */
46
- foundLabel: {
47
- type: String,
48
- attribute: 'found-label'
49
- },
50
- /**
51
- * the current page
52
- */
53
- page: {
54
- type: Number
55
- },
56
- /**
57
- * the amount of pages
58
- */
59
- pageCount: {
60
- type: Number,
61
- attribute: 'page-count'
62
- },
63
- /**
64
- * todo
65
- */
66
- range: {
67
- type: Number
68
- },
69
- /**
70
- * todo:
71
- */
72
- pages: {
73
- type: Array
74
- }
75
- };
18
+ static get properties() {
19
+ return {
20
+ ...super.properties,
21
+ /**
22
+ * total number of pages
23
+ */
24
+ total: {
25
+ type: Number,
26
+ reflect: true,
27
+ },
28
+ /**
29
+ * start page
30
+ */
31
+ start: {
32
+ type: Number,
33
+ reflect: true,
34
+ },
35
+ /**
36
+ * amount of entries per page
37
+ */
38
+ perPage: {
39
+ type: Number,
40
+ attribute: 'per-page',
41
+ },
42
+ /**
43
+ * i18n key to use for looking up the message showing number of items in list
44
+ * or fixed label to display
45
+ */
46
+ foundLabel: {
47
+ type: String,
48
+ attribute: 'found-label',
49
+ },
50
+ /**
51
+ * the current page
52
+ */
53
+ page: {
54
+ type: Number,
55
+ },
56
+ /**
57
+ * the amount of pages
58
+ */
59
+ pageCount: {
60
+ type: Number,
61
+ attribute: 'page-count',
62
+ },
63
+ /**
64
+ * todo
65
+ */
66
+ range: {
67
+ type: Number,
68
+ },
69
+ /**
70
+ * todo:
71
+ */
72
+ pages: {
73
+ type: Array,
74
+ },
75
+ };
76
+ }
77
+
78
+ constructor() {
79
+ super();
80
+ this.total = 0;
81
+ this.start = 1;
82
+ this.perPage = 10;
83
+ this.page = 1;
84
+ this.pageCount = 10;
85
+ this.range = 5;
86
+ this.pages = [];
87
+ this.foundLabel = 'browse.items';
88
+ }
89
+
90
+ connectedCallback() {
91
+ super.connectedCallback();
92
+
93
+ this.subscribeTo('pb-results-received', this._refresh.bind(this));
94
+ }
95
+
96
+ render() {
97
+ return html`
98
+ <span @click="${this._handleFirst}"><iron-icon icon="first-page"></iron-icon></span>
99
+ ${this.pages.map(
100
+ (item, index) =>
101
+ html`<span class="${item.class}" @click="${() => this._handleClick(item, index)}"
102
+ >${item.label}</span
103
+ >`,
104
+ )}
105
+ <span @click="${this._handleLast}"><iron-icon icon="last-page"></iron-icon></span>
106
+
107
+ <span class="found" part="count">${translate(this.foundLabel, { count: this.total })}</span>
108
+ `;
109
+ }
110
+
111
+ static get styles() {
112
+ return css`
113
+ :host([total='0']) {
114
+ display: none;
115
+ }
116
+
117
+ :host {
118
+ display: flex;
119
+ flex-direction: row;
120
+ align-items: center;
121
+ }
122
+
123
+ span {
124
+ padding: 4px 8px;
125
+ cursor: pointer;
126
+ }
127
+
128
+ .active {
129
+ background-color: var(--pb-color-primary);
130
+ color: var(--pb-color-inverse);
131
+ border-radius: 50%;
132
+ min-width: 1em;
133
+ width: 1em;
134
+ line-height: 1em;
135
+ padding: 0.4em;
136
+ text-align: center;
137
+
138
+ box-shadow: 0 3px 4px 0 rgba(0, 0, 0, 0.14), 0 1px 8px 0 rgba(0, 0, 0, 0.12),
139
+ 0 3px 3px -2px rgba(0, 0, 0, 0.4);
140
+ }
141
+
142
+ .found {
143
+ padding-left: 20px;
144
+ }
145
+ `;
146
+ }
147
+
148
+ _update(start, total) {
149
+ if (!total || !start) {
150
+ return;
76
151
  }
77
-
78
- constructor() {
79
- super();
80
- this.total = 0;
81
- this.start = 1;
82
- this.perPage = 10;
83
- this.page = 1;
84
- this.pageCount = 10;
85
- this.range = 5;
86
- this.pages = [];
87
- this.foundLabel = 'browse.items';
88
- }
89
-
90
- connectedCallback() {
91
- super.connectedCallback();
92
-
93
- this.subscribeTo('pb-results-received', this._refresh.bind(this));
94
- }
95
-
96
- render() {
97
- return html`
98
- <span @click="${this._handleFirst}"><iron-icon icon="first-page"></iron-icon></span>
99
- ${this.pages.map((item, index) => html`<span class="${item.class}" @click="${() => this._handleClick(item, index)}">${item.label}</span>`)}
100
- <span @click="${this._handleLast}"><iron-icon icon="last-page"></iron-icon></span>
101
-
102
- <span class="found" part="count">${translate(this.foundLabel, { count: this.total })}</span>
103
- `;
104
- }
105
-
106
- static get styles() {
107
- return css`
108
- :host([total="0"]) {
109
- display: none;
110
- }
111
-
112
- :host {
113
- display: flex;
114
- flex-direction: row;
115
- align-items: center;
116
- }
117
-
118
- span {
119
- padding: 4px 8px;
120
- cursor: pointer;
121
- }
122
-
123
- .active {
124
- background-color: var(--pb-color-primary);
125
- color: var(--pb-color-inverse);
126
- border-radius: 50%;
127
- min-width: 1em;
128
- width: 1em;
129
- line-height: 1em;
130
- padding: .4em;
131
- text-align: center;
132
-
133
- box-shadow: 0 3px 4px 0 rgba(0, 0, 0, 0.14),
134
- 0 1px 8px 0 rgba(0, 0, 0, 0.12),
135
- 0 3px 3px -2px rgba(0, 0, 0, 0.4);
136
- }
137
-
138
- .found {
139
- padding-left: 20px;
140
- }
141
- `;
142
- }
143
-
144
- _update(start, total) {
145
- if (!total || !start) {
146
- return;
147
- }
148
- this.pageCount = Math.ceil(total / this.perPage);
149
- this.page = Math.ceil(start / this.perPage);
150
- let lowerBound = Math.max((this.page - Math.ceil(this.range / 2) + 1), 1);
151
- let upperBound = Math.min((lowerBound + this.range - 1), this.pageCount);
152
- lowerBound = Math.max((upperBound - this.range + 1), 1);
153
- console.log("<pb-paginate> start: %d, total: %d, perPage: %d, pageCount: %s, page: %d, lower: %d, upper: %d",
154
- start, total, this.perPage, this.pageCount, this.page, lowerBound, upperBound);
155
- const pages = [];
156
- for (let i = lowerBound; i <= upperBound; i++) {
157
- pages.push({
158
- label: i,
159
- "class": i === this.page ? "active" : ""
160
- });
161
- }
162
- this.pages = pages;
163
- }
164
-
165
- _refresh(ev) {
166
- this.start = Number(ev.detail.start);
167
- this.total = ev.detail.count;
168
- this._update(this.start, this.total);
169
- }
170
-
171
- _handleClick(item, index) {
172
- this.start = (this.pages[index].label - 1) * this.perPage + 1;
173
- ['pb-load', 'pb-paginate'].forEach((ev) => {
174
- this.emitTo(ev, {
175
- "params": {
176
- "start": this.start,
177
- "per-page": this.perPage,
178
- "page": index
179
- }
180
- });
181
- });
182
- }
183
-
184
- _handleFirst(ev) {
185
- this.start = 1;
186
- ['pb-load', 'pb-paginate'].forEach((event) => {
187
- this.emitTo(event, {
188
- "params": {
189
- "start": 1,
190
- "per-page": this.perPage,
191
- "page": 0
192
- }
193
- });
194
- });
195
- }
196
-
197
- _handleLast(ev) {
198
- this.start = (this.pageCount - 1) * this.perPage + 1;
199
- ['pb-load', 'pb-paginate'].forEach((event) => {
200
- this.emitTo(event, {
201
- "params": {
202
- "start": this.start,
203
- "per-page": this.perPage,
204
- "page": this.pageCount - 1
205
- }
206
- });
207
- });
152
+ this.pageCount = Math.ceil(total / this.perPage);
153
+ this.page = Math.ceil(start / this.perPage);
154
+ let lowerBound = Math.max(this.page - Math.ceil(this.range / 2) + 1, 1);
155
+ const upperBound = Math.min(lowerBound + this.range - 1, this.pageCount);
156
+ lowerBound = Math.max(upperBound - this.range + 1, 1);
157
+ console.log(
158
+ '<pb-paginate> start: %d, total: %d, perPage: %d, pageCount: %s, page: %d, lower: %d, upper: %d',
159
+ start,
160
+ total,
161
+ this.perPage,
162
+ this.pageCount,
163
+ this.page,
164
+ lowerBound,
165
+ upperBound,
166
+ );
167
+ const pages = [];
168
+ for (let i = lowerBound; i <= upperBound; i++) {
169
+ pages.push({
170
+ label: i,
171
+ class: i === this.page ? 'active' : '',
172
+ });
208
173
  }
174
+ this.pages = pages;
175
+ }
176
+
177
+ _refresh(ev) {
178
+ this.start = Number(ev.detail.start);
179
+ this.total = ev.detail.count;
180
+ this._update(this.start, this.total);
181
+ }
182
+
183
+ _handleClick(item, index) {
184
+ this.start = (this.pages[index].label - 1) * this.perPage + 1;
185
+ ['pb-load', 'pb-paginate'].forEach(ev => {
186
+ this.emitTo(ev, {
187
+ params: {
188
+ start: this.start,
189
+ 'per-page': this.perPage,
190
+ page: index,
191
+ },
192
+ });
193
+ });
194
+ }
195
+
196
+ _handleFirst(ev) {
197
+ this.start = 1;
198
+ ['pb-load', 'pb-paginate'].forEach(event => {
199
+ this.emitTo(event, {
200
+ params: {
201
+ start: 1,
202
+ 'per-page': this.perPage,
203
+ page: 0,
204
+ },
205
+ });
206
+ });
207
+ }
208
+
209
+ _handleLast(ev) {
210
+ this.start = (this.pageCount - 1) * this.perPage + 1;
211
+ ['pb-load', 'pb-paginate'].forEach(event => {
212
+ this.emitTo(event, {
213
+ params: {
214
+ start: this.start,
215
+ 'per-page': this.perPage,
216
+ page: this.pageCount - 1,
217
+ },
218
+ });
219
+ });
220
+ }
209
221
  }
210
222
  customElements.define('pb-paginate', PbPaginate);