svelte-common 6.17.3 → 6.18.0

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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "svelte-common",
3
- "version": "6.17.3",
3
+ "version": "6.18.0",
4
4
  "publishConfig": {
5
5
  "access": "public",
6
6
  "provenance": true
@@ -124,7 +124,7 @@ export class Pagination {
124
124
  const numberOfPages = this.numberOfPages;
125
125
 
126
126
  n = Math.floor(n);
127
-
127
+
128
128
  if (n < 0) {
129
129
  n = numberOfPages + n + 1;
130
130
  } else {
@@ -171,7 +171,7 @@ export class Pagination {
171
171
  }
172
172
 
173
173
  /**
174
- *
174
+ * Calculate item index range for a given page number.
175
175
  * @param {number} page 1...
176
176
  * @returns {[number,number]}
177
177
  */
@@ -295,7 +295,7 @@ export function pageNavigation(elem, pg) {
295
295
  }
296
296
 
297
297
  export const defaultNavigationItemOptions = {
298
- numberOfItems: 7,
298
+ numberOfItems: 9,
299
299
  spreads: [[0], [1, 5, 25, 125, 625, 3125, 15625], [2, 3, 4, 10, 50, 100, 500]]
300
300
  };
301
301
 
@@ -303,25 +303,35 @@ export const defaultNavigationItemOptions = {
303
303
  * Generate actual sequence of page numbers to navigate to.
304
304
  * @param {number} numberOfPages
305
305
  * @param {number} currentPage
306
- * @param {Object} options
307
- * @param {Number} options.numberOfItems
308
- * @param {Number[][]} options.spreads
306
+ * @param {Object|number} optionsOrNumberOfItems
307
+ * @param {number} optionsOrNumberOfItems.numberOfItems
308
+ * @param {number[][]} optionsOrNumberOfItems.spreads
309
309
  * @return {Iterable<number>}
310
310
  */
311
- export function navigationItems(
312
- numberOfPages,
313
- currentPage,
314
- options = defaultNavigationItemOptions
315
- ) {
311
+ export function navigationItems(numberOfPages, currentPage, optionsOrNumberOfItems) {
316
312
  if (numberOfPages === 0) {
317
313
  return [];
318
314
  }
319
315
 
316
+ switch (typeof optionsOrNumberOfItems) {
317
+ case "number":
318
+ optionsOrNumberOfItems = Object.assign({}, defaultNavigationItemOptions, {
319
+ numberOfItems: optionsOrNumberOfItems
320
+ });
321
+ break;
322
+ case "undefined":
323
+ optionsOrNumberOfItems = defaultNavigationItemOptions;
324
+ break;
325
+
326
+ default:
327
+ optionsOrNumberOfItems = Object.assign({}, optionsOrNumberOfItems, defaultNavigationItemOptions);
328
+ }
329
+
320
330
  const items = new Set();
321
331
 
322
332
  const spread = (n, sides) => {
323
333
  for (const side of sides) {
324
- if (items.size === options.numberOfItems) {
334
+ if (items.size === optionsOrNumberOfItems.numberOfItems) {
325
335
  return true;
326
336
  }
327
337
  if (n - side >= 1) {
@@ -334,7 +344,7 @@ export function navigationItems(
334
344
  return false;
335
345
  };
336
346
 
337
- for (const s of options.spreads) {
347
+ for (const s of optionsOrNumberOfItems.spreads) {
338
348
  if (spread(currentPage, s) || spread(1, s) || spread(numberOfPages, s)) {
339
349
  break;
340
350
  }
@@ -3,15 +3,12 @@ export function pageNavigation(elem: any, pg: any): void;
3
3
  * Generate actual sequence of page numbers to navigate to.
4
4
  * @param {number} numberOfPages
5
5
  * @param {number} currentPage
6
- * @param {Object} options
7
- * @param {Number} options.numberOfItems
8
- * @param {Number[][]} options.spreads
6
+ * @param {Object|number} optionsOrNumberOfItems
7
+ * @param {number} optionsOrNumberOfItems.numberOfItems
8
+ * @param {number[][]} optionsOrNumberOfItems.spreads
9
9
  * @return {Iterable<number>}
10
10
  */
11
- export function navigationItems(numberOfPages: number, currentPage: number, options?: {
12
- numberOfItems: number;
13
- spreads: number[][];
14
- }): Iterable<number>;
11
+ export function navigationItems(numberOfPages: number, currentPage: number, optionsOrNumberOfItems: any | number): Iterable<number>;
15
12
  /**
16
13
  * Pagination support store.
17
14
  * Pages go from 1 ... numberOfPages
@@ -53,7 +50,7 @@ export class Pagination {
53
50
  */
54
51
  get numberOfItems(): number;
55
52
  /**
56
- *
53
+ * Calculate item index range for a given page number.
57
54
  * @param {number} page 1...
58
55
  * @returns {[number,number]}
59
56
  */