@myrmidon/paged-data-browsers 2.0.4 → 3.0.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/fesm2022/myrmidon-paged-data-browsers.mjs +24 -16
- package/fesm2022/myrmidon-paged-data-browsers.mjs.map +1 -1
- package/lib/components/browser-tree-node/browser-tree-node.component.d.ts +5 -1
- package/package.json +7 -9
- package/esm2022/lib/components/browser-tree-node/browser-tree-node.component.mjs +0 -86
- package/esm2022/lib/components/compact-pager/compact-pager.component.mjs +0 -47
- package/esm2022/lib/components/range-view/range-view.component.mjs +0 -35
- package/esm2022/lib/paged-data-browsers.module.mjs +0 -92
- package/esm2022/lib/services/lru-cache.mjs +0 -119
- package/esm2022/lib/services/paged-list.store.mjs +0 -172
- package/esm2022/lib/services/paged-tree.store.mjs +0 -419
- package/esm2022/myrmidon-paged-data-browsers.mjs +0 -5
- package/esm2022/public-api.mjs +0 -11
|
@@ -1,172 +0,0 @@
|
|
|
1
|
-
import { BehaviorSubject } from 'rxjs';
|
|
2
|
-
import { LRUCache } from './lru-cache';
|
|
3
|
-
/**
|
|
4
|
-
* Default options for the paged list store.
|
|
5
|
-
*/
|
|
6
|
-
export const DEFAULT_PAGED_LIST_STORE_OPTIONS = {
|
|
7
|
-
pageSize: 20,
|
|
8
|
-
cacheSize: 50,
|
|
9
|
-
};
|
|
10
|
-
/**
|
|
11
|
-
* A generic paged list store using a filter object of type F
|
|
12
|
-
* and a list of elements of type E.
|
|
13
|
-
*/
|
|
14
|
-
export class PagedListStore {
|
|
15
|
-
/**
|
|
16
|
-
* The size of nodes pages in this store. If you change it, the store
|
|
17
|
-
* is reset. The default value is 20.
|
|
18
|
-
*/
|
|
19
|
-
get pageSize() {
|
|
20
|
-
return this._pageSize;
|
|
21
|
-
}
|
|
22
|
-
set pageSize(value) {
|
|
23
|
-
if (this._pageSize === value) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
this._pageSize = value;
|
|
27
|
-
this.reset();
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Create a new paged list store.
|
|
31
|
-
* @param options Options for the paged list store.
|
|
32
|
-
*/
|
|
33
|
-
constructor(_service, options = DEFAULT_PAGED_LIST_STORE_OPTIONS) {
|
|
34
|
-
this._service = _service;
|
|
35
|
-
this._pageSize = options.pageSize;
|
|
36
|
-
this._cache = new LRUCache(options.cacheSize);
|
|
37
|
-
// page
|
|
38
|
-
this._page$ = new BehaviorSubject({
|
|
39
|
-
pageNumber: 0,
|
|
40
|
-
pageCount: 0,
|
|
41
|
-
pageSize: 0,
|
|
42
|
-
total: 0,
|
|
43
|
-
items: [],
|
|
44
|
-
});
|
|
45
|
-
this.page$ = this._page$.asObservable();
|
|
46
|
-
// filter
|
|
47
|
-
this._filter$ = new BehaviorSubject({});
|
|
48
|
-
this.filter$ = this._filter$.asObservable();
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Returns true if the store is empty, false otherwise.
|
|
52
|
-
* @returns true if the store is empty, false otherwise.
|
|
53
|
-
*/
|
|
54
|
-
isEmpty() {
|
|
55
|
-
return this._page$.value.items.length === 0;
|
|
56
|
-
}
|
|
57
|
-
/**
|
|
58
|
-
* Build the cache key for the given page number and filter.
|
|
59
|
-
* The default implementation just returns a stringified object
|
|
60
|
-
* containing the page number and the filter. You may override
|
|
61
|
-
* this method to provide a custom cache key.
|
|
62
|
-
* @param pageNumber The page number.
|
|
63
|
-
* @param filter The filter.
|
|
64
|
-
* @returns A string to be used as cache key.
|
|
65
|
-
*/
|
|
66
|
-
buildCacheKey(pageNumber, filter) {
|
|
67
|
-
if (this._customCacheKeyBuilder) {
|
|
68
|
-
return this._customCacheKeyBuilder(pageNumber, filter);
|
|
69
|
-
}
|
|
70
|
-
return JSON.stringify({ pageNumber, ...filter });
|
|
71
|
-
}
|
|
72
|
-
/**
|
|
73
|
-
* Load the page with the given number.
|
|
74
|
-
* @param pageNumber the page number to load.
|
|
75
|
-
*/
|
|
76
|
-
loadPage(pageNumber) {
|
|
77
|
-
return this._service.loadPage(pageNumber, this._pageSize, this._filter$.value);
|
|
78
|
-
}
|
|
79
|
-
/**
|
|
80
|
-
* Set the page with the given number.
|
|
81
|
-
* @param pageNumber The page number to load.
|
|
82
|
-
* @param pageSize The page size.
|
|
83
|
-
* @returns Promise which resolves when the page is loaded.
|
|
84
|
-
*/
|
|
85
|
-
setPage(pageNumber, pageSize) {
|
|
86
|
-
if (pageSize && pageSize !== this._pageSize) {
|
|
87
|
-
this._pageSize = pageSize;
|
|
88
|
-
}
|
|
89
|
-
return new Promise((resolve, reject) => {
|
|
90
|
-
// if page is in cache, return it
|
|
91
|
-
const key = this.buildCacheKey(pageNumber, this._filter$.value);
|
|
92
|
-
const cachedPage = this._cache.get(key);
|
|
93
|
-
if (cachedPage) {
|
|
94
|
-
this._page$.next(cachedPage);
|
|
95
|
-
resolve();
|
|
96
|
-
return;
|
|
97
|
-
}
|
|
98
|
-
// else load page
|
|
99
|
-
this.loadPage(pageNumber).subscribe({
|
|
100
|
-
next: (page) => {
|
|
101
|
-
this._page$.next(page);
|
|
102
|
-
this._cache.put(key, page, 0);
|
|
103
|
-
resolve();
|
|
104
|
-
},
|
|
105
|
-
error: reject,
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* Get the current page.
|
|
111
|
-
* @returns The current page.
|
|
112
|
-
*/
|
|
113
|
-
getPage() {
|
|
114
|
-
return this._page$.value;
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* Apply the given filter and load the first page.
|
|
118
|
-
* @param filter The filter to apply.
|
|
119
|
-
* @returns Promise which resolves when the page is loaded.
|
|
120
|
-
*/
|
|
121
|
-
setFilter(filter) {
|
|
122
|
-
return new Promise((resolve, reject) => {
|
|
123
|
-
this._filter$.next(filter);
|
|
124
|
-
this.setPage(1).then(resolve, reject);
|
|
125
|
-
});
|
|
126
|
-
}
|
|
127
|
-
/**
|
|
128
|
-
* Get the current filter.
|
|
129
|
-
* @returns The current filter.
|
|
130
|
-
*/
|
|
131
|
-
getFilter() {
|
|
132
|
-
return this._filter$.value;
|
|
133
|
-
}
|
|
134
|
-
/**
|
|
135
|
-
* Reset the filter and load the first page. The cache is cleared.
|
|
136
|
-
* @returns Promise which resolves when the page is loaded.
|
|
137
|
-
*/
|
|
138
|
-
reset() {
|
|
139
|
-
this._cache.clear();
|
|
140
|
-
return this.setFilter({});
|
|
141
|
-
}
|
|
142
|
-
/**
|
|
143
|
-
* Clear the store. The cache is cleared and the page is emptied.
|
|
144
|
-
*/
|
|
145
|
-
clear() {
|
|
146
|
-
this._cache.clear();
|
|
147
|
-
this._page$.next({
|
|
148
|
-
pageNumber: 0,
|
|
149
|
-
pageCount: 0,
|
|
150
|
-
pageSize: 0,
|
|
151
|
-
total: 0,
|
|
152
|
-
items: [],
|
|
153
|
-
});
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Clear the cache.
|
|
157
|
-
*/
|
|
158
|
-
clearCache() {
|
|
159
|
-
this._cache.clear();
|
|
160
|
-
}
|
|
161
|
-
/**
|
|
162
|
-
* Check if the page with the given number and filter is in cache.
|
|
163
|
-
* @param pageNumber The page number.
|
|
164
|
-
* @param filter The filter.
|
|
165
|
-
* @returns True if the page is in cache, false otherwise.
|
|
166
|
-
*/
|
|
167
|
-
hasCachedPage(pageNumber, filter) {
|
|
168
|
-
const key = this.buildCacheKey(pageNumber, filter);
|
|
169
|
-
return this._cache.has(key);
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paged-list.store.js","sourceRoot":"","sources":["../../../../../../projects/myrmidon/paged-data-browsers/src/lib/services/paged-list.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Observable } from 'rxjs';\r\n\r\nimport { DataPage } from '@myrmidon/ng-tools';\r\n\r\nimport { LRUCache } from './lru-cache';\r\n\r\n/**\r\n * Options for the paged list store.\r\n */\r\nexport interface PagedListStoreOptions {\r\n  /**\r\n   * The size of pages in the store.\r\n   */\r\n  pageSize: number;\r\n  /**\r\n   * The size of the cache for pages in the store.\r\n   */\r\n  cacheSize: number;\r\n\r\n  /**\r\n   * A custom function for building the cache key for the given page number\r\n   * and filter.\r\n   * @param pageNumber The page number.\r\n   * @param filter The filter.\r\n   * @returns A string to be used as cache key.\r\n   */\r\n  buildCacheKey?: (pageNumber: number, filter: any) => string;\r\n}\r\n\r\n/**\r\n * Default options for the paged list store.\r\n */\r\nexport const DEFAULT_PAGED_LIST_STORE_OPTIONS: PagedListStoreOptions = {\r\n  pageSize: 20,\r\n  cacheSize: 50,\r\n};\r\n\r\n/**\r\n * The interface to be implemented by the service used by PagedListStore.\r\n */\r\nexport interface PagedListStoreService<F, E> {\r\n  /**\r\n   * Load the page with the given number.\r\n   * @param pageNumber The page number to load.\r\n   * @param pageSize The size of the page to load.\r\n   * @param filter The filter to apply.\r\n   */\r\n  loadPage(\r\n    pageNumber: number,\r\n    pageSize: number,\r\n    filter: F\r\n  ): Observable<DataPage<E>>;\r\n}\r\n\r\n/**\r\n * A generic paged list store using a filter object of type F\r\n * and a list of elements of type E.\r\n */\r\nexport class PagedListStore<F, E> {\r\n  private _pageSize: number;\r\n  private readonly _customCacheKeyBuilder?: (\r\n    pageNumber: number,\r\n    filter: any\r\n  ) => string;\r\n  private _page$: BehaviorSubject<DataPage<E>>;\r\n  private _filter$: BehaviorSubject<F>;\r\n  private readonly _cache: LRUCache<DataPage<E>>;\r\n\r\n  /**\r\n   * The page. It is updated when the page is changed or the filter is changed.\r\n   */\r\n  public page$: Observable<Readonly<DataPage<E>>>;\r\n\r\n  /**\r\n   * The filter. It is updated when the filter is changed.\r\n   */\r\n  public filter$: Observable<Readonly<F>>;\r\n\r\n  /**\r\n   * The size of nodes pages in this store. If you change it, the store\r\n   * is reset. The default value is 20.\r\n   */\r\n  public get pageSize(): number {\r\n    return this._pageSize;\r\n  }\r\n  public set pageSize(value: number) {\r\n    if (this._pageSize === value) {\r\n      return;\r\n    }\r\n    this._pageSize = value;\r\n    this.reset();\r\n  }\r\n\r\n  /**\r\n   * Create a new paged list store.\r\n   * @param options Options for the paged list store.\r\n   */\r\n  constructor(\r\n    private _service: PagedListStoreService<F, E>,\r\n    options: PagedListStoreOptions = DEFAULT_PAGED_LIST_STORE_OPTIONS\r\n  ) {\r\n    this._pageSize = options.pageSize;\r\n    this._cache = new LRUCache<DataPage<E>>(options.cacheSize);\r\n    // page\r\n    this._page$ = new BehaviorSubject<DataPage<E>>({\r\n      pageNumber: 0,\r\n      pageCount: 0,\r\n      pageSize: 0,\r\n      total: 0,\r\n      items: [],\r\n    });\r\n    this.page$ = this._page$.asObservable();\r\n    // filter\r\n    this._filter$ = new BehaviorSubject<F>({} as F);\r\n    this.filter$ = this._filter$.asObservable();\r\n  }\r\n\r\n  /**\r\n   * Returns true if the store is empty, false otherwise.\r\n   * @returns true if the store is empty, false otherwise.\r\n   */\r\n  public isEmpty(): boolean {\r\n    return this._page$.value.items.length === 0;\r\n  }\r\n\r\n  /**\r\n   * Build the cache key for the given page number and filter.\r\n   * The default implementation just returns a stringified object\r\n   * containing the page number and the filter. You may override\r\n   * this method to provide a custom cache key.\r\n   * @param pageNumber The page number.\r\n   * @param filter The filter.\r\n   * @returns A string to be used as cache key.\r\n   */\r\n  public buildCacheKey(pageNumber: number, filter: F): string {\r\n    if (this._customCacheKeyBuilder) {\r\n      return this._customCacheKeyBuilder(pageNumber, filter);\r\n    }\r\n    return JSON.stringify({ pageNumber, ...filter });\r\n  }\r\n\r\n  /**\r\n   * Load the page with the given number.\r\n   * @param pageNumber the page number to load.\r\n   */\r\n  private loadPage(pageNumber: number): Observable<DataPage<E>> {\r\n    return this._service.loadPage(\r\n      pageNumber,\r\n      this._pageSize,\r\n      this._filter$.value\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Set the page with the given number.\r\n   * @param pageNumber The page number to load.\r\n   * @param pageSize The page size.\r\n   * @returns Promise which resolves when the page is loaded.\r\n   */\r\n  public setPage(pageNumber: number, pageSize?: number): Promise<void> {\r\n    if (pageSize && pageSize !== this._pageSize) {\r\n      this._pageSize = pageSize;\r\n    }\r\n    return new Promise((resolve, reject) => {\r\n      // if page is in cache, return it\r\n      const key = this.buildCacheKey(pageNumber, this._filter$.value);\r\n      const cachedPage = this._cache.get(key);\r\n      if (cachedPage) {\r\n        this._page$.next(cachedPage);\r\n        resolve();\r\n        return;\r\n      }\r\n\r\n      // else load page\r\n      this.loadPage(pageNumber).subscribe({\r\n        next: (page) => {\r\n          this._page$.next(page);\r\n          this._cache.put(key, page, 0);\r\n          resolve();\r\n        },\r\n        error: reject,\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Get the current page.\r\n   * @returns The current page.\r\n   */\r\n  public getPage(): DataPage<E> {\r\n    return this._page$.value;\r\n  }\r\n\r\n  /**\r\n   * Apply the given filter and load the first page.\r\n   * @param filter The filter to apply.\r\n   * @returns Promise which resolves when the page is loaded.\r\n   */\r\n  public setFilter(filter: F): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      this._filter$.next(filter);\r\n      this.setPage(1).then(resolve, reject);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Get the current filter.\r\n   * @returns The current filter.\r\n   */\r\n  public getFilter(): F {\r\n    return this._filter$.value;\r\n  }\r\n\r\n  /**\r\n   * Reset the filter and load the first page. The cache is cleared.\r\n   * @returns Promise which resolves when the page is loaded.\r\n   */\r\n  public reset(): Promise<void> {\r\n    this._cache.clear();\r\n    return this.setFilter({} as F);\r\n  }\r\n\r\n  /**\r\n   * Clear the store. The cache is cleared and the page is emptied.\r\n   */\r\n  public clear(): void {\r\n    this._cache.clear();\r\n    this._page$.next({\r\n      pageNumber: 0,\r\n      pageCount: 0,\r\n      pageSize: 0,\r\n      total: 0,\r\n      items: [],\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Clear the cache.\r\n   */\r\n  public clearCache(): void {\r\n    this._cache.clear();\r\n  }\r\n\r\n  /**\r\n   * Check if the page with the given number and filter is in cache.\r\n   * @param pageNumber The page number.\r\n   * @param filter The filter.\r\n   * @returns True if the page is in cache, false otherwise.\r\n   */\r\n  public hasCachedPage(pageNumber: number, filter: F): boolean {\r\n    const key = this.buildCacheKey(pageNumber, filter);\r\n    return this._cache.has(key);\r\n  }\r\n}\r\n"]}
|