@ng-atomic/common 5.8.1 → 5.10.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/esm2020/pipes/select-id/index.mjs +2 -0
- package/esm2020/pipes/select-id/ng-atomic-common-pipes-select-id.mjs +5 -0
- package/esm2020/pipes/select-id/select-id.pipe.mjs +26 -0
- package/esm2020/services/loading/loading.service.mjs +5 -7
- package/esm2020/stores/entities/entities.store.mjs +2 -1
- package/fesm2015/ng-atomic-common-pipes-select-id.mjs +35 -0
- package/fesm2015/ng-atomic-common-pipes-select-id.mjs.map +1 -0
- package/fesm2015/ng-atomic-common-services-loading.mjs +4 -6
- package/fesm2015/ng-atomic-common-services-loading.mjs.map +1 -1
- package/fesm2015/ng-atomic-common-stores-entities.mjs +1 -0
- package/fesm2015/ng-atomic-common-stores-entities.mjs.map +1 -1
- package/fesm2020/ng-atomic-common-pipes-select-id.mjs +33 -0
- package/fesm2020/ng-atomic-common-pipes-select-id.mjs.map +1 -0
- package/fesm2020/ng-atomic-common-services-loading.mjs +4 -6
- package/fesm2020/ng-atomic-common-services-loading.mjs.map +1 -1
- package/fesm2020/ng-atomic-common-stores-entities.mjs +1 -0
- package/fesm2020/ng-atomic-common-stores-entities.mjs.map +1 -1
- package/package.json +10 -2
- package/pipes/select-id/index.d.ts +1 -0
- package/pipes/select-id/select-id.pipe.d.ts +12 -0
- package/services/loading/loading.service.d.ts +2 -2
- package/stores/entities/entities.store.d.ts +3 -2
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './select-id.pipe';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvcGlwZXMvc2VsZWN0LWlkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NlbGVjdC1pZC5waXBlJztcbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctYXRvbWljLWNvbW1vbi1waXBlcy1zZWxlY3QtaWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvcGlwZXMvc2VsZWN0LWlkL25nLWF0b21pYy1jb21tb24tcGlwZXMtc2VsZWN0LWlkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Inject, InjectionToken, Pipe } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export const SELECT_ID = new InjectionToken('[@ng-atomic/common] Select Id');
|
|
4
|
+
export const defaultSelectId = (entity) => entity.Id;
|
|
5
|
+
export class SelectIdPipe {
|
|
6
|
+
constructor(selectId) {
|
|
7
|
+
this.selectId = selectId;
|
|
8
|
+
}
|
|
9
|
+
transform(entity) {
|
|
10
|
+
return this.selectId(entity);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
SelectIdPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, deps: [{ token: SELECT_ID }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
14
|
+
SelectIdPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, isStandalone: true, name: "selectId" });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, decorators: [{
|
|
16
|
+
type: Pipe,
|
|
17
|
+
args: [{
|
|
18
|
+
name: 'selectId',
|
|
19
|
+
pure: true,
|
|
20
|
+
standalone: true,
|
|
21
|
+
}]
|
|
22
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
23
|
+
type: Inject,
|
|
24
|
+
args: [SELECT_ID]
|
|
25
|
+
}] }]; } });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWlkLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvcGlwZXMvc2VsZWN0LWlkL3NlbGVjdC1pZC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHN0QsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLElBQUksY0FBYyxDQUFXLCtCQUErQixDQUFDLENBQUM7QUFDdkYsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFhLENBQUMsTUFBVyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO0FBT3BFLE1BQU0sT0FBTyxZQUFZO0lBQ3ZCLFlBQytCLFFBQWtCO1FBQWxCLGFBQVEsR0FBUixRQUFRLENBQVU7SUFDOUMsQ0FBQztJQUVKLFNBQVMsQ0FBQyxNQUFXO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMvQixDQUFDOzt5R0FQVSxZQUFZLGtCQUViLFNBQVM7dUdBRlIsWUFBWTsyRkFBWixZQUFZO2tCQUx4QixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxVQUFVO29CQUNoQixJQUFJLEVBQUUsSUFBSTtvQkFDVixVQUFVLEVBQUUsSUFBSTtpQkFDakI7OzBCQUdJLE1BQU07MkJBQUMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0aW9uVG9rZW4sIFBpcGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5leHBvcnQgdHlwZSBTZWxlY3RJZCA9IChlbnRpdHk6IG9iamVjdCkgPT4gc3RyaW5nIHwgbnVtYmVyO1xuZXhwb3J0IGNvbnN0IFNFTEVDVF9JRCA9IG5ldyBJbmplY3Rpb25Ub2tlbjxTZWxlY3RJZD4oJ1tAbmctYXRvbWljL2NvbW1vbl0gU2VsZWN0IElkJyk7XG5leHBvcnQgY29uc3QgZGVmYXVsdFNlbGVjdElkOiBTZWxlY3RJZCA9IChlbnRpdHk6IGFueSkgPT4gZW50aXR5LklkO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdzZWxlY3RJZCcsXG4gIHB1cmU6IHRydWUsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFNlbGVjdElkUGlwZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoU0VMRUNUX0lEKSBwcm90ZWN0ZWQgc2VsZWN0SWQ6IFNlbGVjdElkXG4gICkge31cblxuICB0cmFuc2Zvcm0oZW50aXR5OiBhbnkpOiBzdHJpbmcgfCBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLnNlbGVjdElkKGVudGl0eSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,15 +1,13 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
|
-
import { scan, map, distinctUntilChanged, delay } from 'rxjs/operators';
|
|
3
|
+
import { scan, map, distinctUntilChanged, delay, tap, shareReplay } from 'rxjs/operators';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class LoadingService {
|
|
6
6
|
constructor() {
|
|
7
7
|
this.loadingEntries$ = new Subject();
|
|
8
|
-
this.loadingMap =
|
|
9
|
-
this.loadingMap$ = this.loadingEntries$.pipe(scan((
|
|
10
|
-
|
|
11
|
-
.reduce((p, [k, v]) => ({ ...p, [k]: v }), {})), distinctUntilChanged((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur)));
|
|
12
|
-
this.isLoading$ = this.loadingMap$.pipe(map((m) => !!Object.keys(m).length), delay(0));
|
|
8
|
+
this.loadingMap = new Map();
|
|
9
|
+
this.loadingMap$ = this.loadingEntries$.pipe(scan((map, [key, value]) => map.set(key, value), new Map()), map((map) => new Map([...map.entries()].filter(([_, v]) => v))), tap(m => console.debug('m:', m)), distinctUntilChanged((pre, cur) => JSON.stringify([...pre.entries()]) === JSON.stringify([...cur.entries()])), shareReplay(1));
|
|
10
|
+
this.isLoading$ = this.loadingMap$.pipe(map((map) => !![...map.keys()].length), delay(0));
|
|
13
11
|
this.loadingMap$.subscribe((m) => {
|
|
14
12
|
this.loadingMap = m;
|
|
15
13
|
});
|
|
@@ -42,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImpor
|
|
|
42
40
|
export function randomStr(n = 16) {
|
|
43
41
|
return Math.random().toString(36).substr(2, n);
|
|
44
42
|
}
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb21tb24vc3JjL3NlcnZpY2VzL2xvYWRpbmcvbG9hZGluZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQixPQUFPLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxvQkFBb0IsRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQU8xRixNQUFNLE9BQU8sY0FBYztJQWlCekI7UUFoQlEsb0JBQWUsR0FBRyxJQUFJLE9BQU8sRUFBcUIsQ0FBQztRQUUzRCxlQUFVLEdBQWUsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUNuQyxnQkFBVyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUNyQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLElBQUksR0FBRyxFQUFFLENBQUMsRUFDM0QsR0FBRyxDQUFDLENBQUMsR0FBZSxFQUFFLEVBQUUsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFvQixFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQzlGLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQ2hDLG9CQUFvQixDQUFDLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxHQUFHLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQzdHLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FDZixDQUFDO1FBRUYsZUFBVSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUNoQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQ3RDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FDVCxDQUFDO1FBR0EsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUMvQixJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxNQUFNLENBQUMsR0FBVztRQUNoQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxTQUFTLENBQUMsR0FBVztRQUNuQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRCxLQUFLLENBQUMsUUFBNkIsRUFBRSxNQUFjLFNBQVMsQ0FBQyxFQUFFLENBQUM7UUFDOUQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNqQixRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQTJDO1FBQ3JELE1BQU0sR0FBRyxHQUFHLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2pCLE1BQU0sUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN0QixDQUFDOzsyR0F6Q1UsY0FBYzsrR0FBZCxjQUFjLGNBRmIsTUFBTTsyRkFFUCxjQUFjO2tCQUgxQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7QUE2Q0QsTUFBTSxVQUFVLFNBQVMsQ0FBQyxJQUFZLEVBQUU7SUFDdEMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDakQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IHNjYW4sIG1hcCwgZGlzdGluY3RVbnRpbENoYW5nZWQsIGRlbGF5LCB0YXAsIHNoYXJlUmVwbGF5IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG50eXBlIExvYWRpbmdNYXAgPSBNYXA8c3RyaW5nLCBib29sZWFuPjtcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIExvYWRpbmdTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBsb2FkaW5nRW50cmllcyQgPSBuZXcgU3ViamVjdDxbc3RyaW5nLCBib29sZWFuXT4oKTtcblxuICBsb2FkaW5nTWFwOiBMb2FkaW5nTWFwID0gbmV3IE1hcCgpO1xuICBsb2FkaW5nTWFwJCA9IHRoaXMubG9hZGluZ0VudHJpZXMkLnBpcGUoXG4gICAgc2NhbigobWFwLCBba2V5LCB2YWx1ZV0pID0+IG1hcC5zZXQoa2V5LCB2YWx1ZSksIG5ldyBNYXAoKSksXG4gICAgbWFwKChtYXA6IExvYWRpbmdNYXApID0+IG5ldyBNYXAoWy4uLm1hcC5lbnRyaWVzKCldLmZpbHRlcigoW18sIHZdOiBbc3RyaW5nLCBib29sZWFuXSkgPT4gdikpKSxcbiAgICB0YXAobSA9PiBjb25zb2xlLmRlYnVnKCdtOicsIG0pKSxcbiAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgocHJlLCBjdXIpID0+IEpTT04uc3RyaW5naWZ5KFsuLi5wcmUuZW50cmllcygpXSkgPT09IEpTT04uc3RyaW5naWZ5KFsuLi5jdXIuZW50cmllcygpXSkpLFxuICAgIHNoYXJlUmVwbGF5KDEpLFxuICApO1xuXG4gIGlzTG9hZGluZyQgPSB0aGlzLmxvYWRpbmdNYXAkLnBpcGUoXG4gICAgbWFwKChtYXApID0+ICEhWy4uLm1hcC5rZXlzKCldLmxlbmd0aCksXG4gICAgZGVsYXkoMCksXG4gICk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5sb2FkaW5nTWFwJC5zdWJzY3JpYmUoKG0pID0+IHtcbiAgICAgIHRoaXMubG9hZGluZ01hcCA9IG07XG4gICAgfSk7XG4gIH1cblxuICBzZXRLZXkoa2V5OiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLmxvYWRpbmdFbnRyaWVzJC5uZXh0KFtrZXksIHRydWVdKTtcbiAgfVxuXG4gIHJlbW92ZUtleShrZXk6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMubG9hZGluZ0VudHJpZXMkLm5leHQoW2tleSwgZmFsc2VdKTtcbiAgfVxuXG4gIHN0YXJ0KGNhbGxiYWNrOiAoZG9uZTogYW55KSA9PiB2b2lkLCBrZXk6IHN0cmluZyA9IHJhbmRvbVN0cigxNikpIHtcbiAgICB0aGlzLnNldEtleShrZXkpO1xuICAgIGNhbGxiYWNrKCgpID0+IHRoaXMucmVtb3ZlS2V5KGtleSkpO1xuICB9XG5cbiAgYXN5bmMgYXdhaXQoY2FsbGJhY2s6ICguLi5hcmdzOiBhbnlbXSkgPT4gUHJvbWlzZTx2b2lkPikge1xuICAgIGNvbnN0IGtleSA9IHJhbmRvbVN0cigxNik7XG4gICAgdGhpcy5zZXRLZXkoa2V5KTtcbiAgICBhd2FpdCBjYWxsYmFjaygpO1xuICAgIHRoaXMucmVtb3ZlS2V5KGtleSk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJhbmRvbVN0cihuOiBudW1iZXIgPSAxNik6IHN0cmluZyB7XG4gIHJldHVybiBNYXRoLnJhbmRvbSgpLnRvU3RyaW5nKDM2KS5zdWJzdHIoMiwgbik7XG59Il19
|
|
@@ -11,6 +11,7 @@ export class EntitiesStore extends ComponentStore {
|
|
|
11
11
|
super(initialState);
|
|
12
12
|
this.refresh$ = new ReplaySubject(1);
|
|
13
13
|
this.entities$ = this.select(({ entities }) => entities ? entities.sort(compareById) : []);
|
|
14
|
+
this.size$ = this.select(({ entities }) => entities?.length ?? 0);
|
|
14
15
|
this.setEntities = this.updater((state, entities) => ({ ...state, entities }));
|
|
15
16
|
this.refresh();
|
|
16
17
|
}
|
|
@@ -18,4 +19,4 @@ export class EntitiesStore extends ComponentStore {
|
|
|
18
19
|
this.refresh$.next();
|
|
19
20
|
}
|
|
20
21
|
}
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXRpZXMuc3RvcmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvbW1vbi9zcmMvc3RvcmVzL2VudGl0aWVzL2VudGl0aWVzLnN0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdEQsT0FBTyxFQUFjLGFBQWEsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNqRCxPQUFPLEVBQUUsb0JBQW9CLEVBQTBCLE1BQU0sZ0JBQWdCLENBQUM7QUFNOUUsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUcsR0FBTSxFQUFFO0lBQy9DLE9BQU8sb0JBQW9CLENBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxLQUFLLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUM1RixDQUFDLENBQUM7QUFFRixNQUFNLE9BQWdCLGFBQXdFLFNBQVEsY0FBaUI7SUFHckgsSUFBSSxRQUFRLEtBQUssT0FBTyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUs5QyxZQUFZLFlBQWU7UUFDekIsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBUkgsYUFBUSxHQUFHLElBQUksYUFBYSxDQUFPLENBQUMsQ0FBQyxDQUFDO1FBSXpELGNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBQyxRQUFRLEVBQUMsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNwRixVQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUMsUUFBUSxFQUFDLEVBQUUsRUFBRSxDQUFDLFFBQVEsRUFBRSxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUM7UUFPM0QsZ0JBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLFFBQWEsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFDLEdBQUcsS0FBSyxFQUFFLFFBQVEsRUFBQyxDQUFDLENBQUMsQ0FBQztRQUgzRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDakIsQ0FBQztJQU1ELE9BQU87UUFDTCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3ZCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudFN0b3JlIH0gZnJvbSAnQG5ncngvY29tcG9uZW50LXN0b3JlJztcbmltcG9ydCB7IGNvbXBhcmVCeUlkIH0gZnJvbSAnQG5nLWF0b21pYy9jb21tb24vdXRpbHMnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgUmVwbGF5U3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQsIHRhcCwgZmlsdGVyLCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50aXRpZXNTdGF0ZTxFPiB7XG4gIGVudGl0aWVzOiBFW11cbn1cblxuZXhwb3J0IGNvbnN0IGRpc3RpbmN0VW50aWxDaGFuZ2VkQXJyYXkgPSA8VD4oKSA9PiB7XG4gIHJldHVybiBkaXN0aW5jdFVudGlsQ2hhbmdlZDxUPigocHJlLCBjdXIpID0+IEpTT04uc3RyaW5naWZ5KHByZSkgPT09IEpTT04uc3RyaW5naWZ5KGN1cikpO1xufTtcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEVudGl0aWVzU3RvcmU8RSBleHRlbmRzIHtpZDogc3RyaW5nfSwgUyBleHRlbmRzIEVudGl0aWVzU3RhdGU8RT4gPSBhbnk+IGV4dGVuZHMgQ29tcG9uZW50U3RvcmU8Uz4ge1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgcmVmcmVzaCQgPSBuZXcgUmVwbGF5U3ViamVjdDx2b2lkPigxKTtcblxuICBnZXQgZW50aXRpZXMoKSB7IHJldHVybiB0aGlzLmdldCgpLmVudGl0aWVzOyB9XG5cbiAgZW50aXRpZXMkID0gdGhpcy5zZWxlY3QoKHtlbnRpdGllc30pID0+IGVudGl0aWVzID8gZW50aXRpZXMuc29ydChjb21wYXJlQnlJZCkgOiBbXSk7XG4gIHNpemUkID0gdGhpcy5zZWxlY3QoKHtlbnRpdGllc30pID0+IGVudGl0aWVzPy5sZW5ndGggPz8gMCk7XG4gIFxuICBjb25zdHJ1Y3Rvcihpbml0aWFsU3RhdGU6IFMpIHtcbiAgICBzdXBlcihpbml0aWFsU3RhdGUpO1xuICAgIHRoaXMucmVmcmVzaCgpO1xuICB9XG5cbiAgc2V0RW50aXRpZXMgPSB0aGlzLnVwZGF0ZXIoKHN0YXRlLCBlbnRpdGllczogRVtdKSA9PiAoey4uLnN0YXRlLCBlbnRpdGllc30pKTtcblxuICBhYnN0cmFjdCBnZXRFbnRpdGllczogUmV0dXJuVHlwZTx0eXBlb2YgdGhpcy5lZmZlY3Q+O1xuXG4gIHJlZnJlc2goKSB7XG4gICAgdGhpcy5yZWZyZXNoJC5uZXh0KCk7XG4gIH1cbn0iXX0=
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { InjectionToken, Pipe, Inject } from '@angular/core';
|
|
3
|
+
|
|
4
|
+
const SELECT_ID = new InjectionToken('[@ng-atomic/common] Select Id');
|
|
5
|
+
const defaultSelectId = (entity) => entity.Id;
|
|
6
|
+
class SelectIdPipe {
|
|
7
|
+
constructor(selectId) {
|
|
8
|
+
this.selectId = selectId;
|
|
9
|
+
}
|
|
10
|
+
transform(entity) {
|
|
11
|
+
return this.selectId(entity);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
SelectIdPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, deps: [{ token: SELECT_ID }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
15
|
+
SelectIdPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, isStandalone: true, name: "selectId" });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, decorators: [{
|
|
17
|
+
type: Pipe,
|
|
18
|
+
args: [{
|
|
19
|
+
name: 'selectId',
|
|
20
|
+
pure: true,
|
|
21
|
+
standalone: true,
|
|
22
|
+
}]
|
|
23
|
+
}], ctorParameters: function () {
|
|
24
|
+
return [{ type: undefined, decorators: [{
|
|
25
|
+
type: Inject,
|
|
26
|
+
args: [SELECT_ID]
|
|
27
|
+
}] }];
|
|
28
|
+
} });
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Generated bundle index. Do not edit.
|
|
32
|
+
*/
|
|
33
|
+
|
|
34
|
+
export { SELECT_ID, SelectIdPipe, defaultSelectId };
|
|
35
|
+
//# sourceMappingURL=ng-atomic-common-pipes-select-id.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-pipes-select-id.mjs","sources":["../../../../../packages/@ng-atomic/common/src/pipes/select-id/select-id.pipe.ts","../../../../../packages/@ng-atomic/common/src/pipes/select-id/ng-atomic-common-pipes-select-id.ts"],"sourcesContent":["import { Inject, InjectionToken, Pipe } from \"@angular/core\";\n\nexport type SelectId = (entity: object) => string | number;\nexport const SELECT_ID = new InjectionToken<SelectId>('[@ng-atomic/common] Select Id');\nexport const defaultSelectId: SelectId = (entity: any) => entity.Id;\n\n@Pipe({\n name: 'selectId',\n pure: true,\n standalone: true,\n})\nexport class SelectIdPipe {\n constructor(\n @Inject(SELECT_ID) protected selectId: SelectId\n ) {}\n\n transform(entity: any): string | number {\n return this.selectId(entity);\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;MAGa,SAAS,GAAG,IAAI,cAAc,CAAW,+BAA+B,EAAE;AAChF,MAAM,eAAe,GAAa,CAAC,MAAW,KAAK,MAAM,CAAC,GAAG;MAOvD,YAAY,CAAA;AACvB,IAAA,WAAA,CAC+B,QAAkB,EAAA;AAAlB,QAAA,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAU;KAC7C;AAEJ,IAAA,SAAS,CAAC,MAAW,EAAA;AACnB,QAAA,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;KAC9B;;AAPU,YAAA,CAAA,IAAA,GAAA,EAAA,CAAA,kBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,YAAY,kBAEb,SAAS,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,IAAA,EAAA,CAAA,CAAA;uGAFR,YAAY,EAAA,YAAA,EAAA,IAAA,EAAA,IAAA,EAAA,UAAA,EAAA,CAAA,CAAA;2FAAZ,YAAY,EAAA,UAAA,EAAA,CAAA;kBALxB,IAAI;AAAC,YAAA,IAAA,EAAA,CAAA;AACJ,oBAAA,IAAI,EAAE,UAAU;AAChB,oBAAA,IAAI,EAAE,IAAI;AACV,oBAAA,UAAU,EAAE,IAAI;iBACjB,CAAA;;;8BAGI,MAAM;+BAAC,SAAS,CAAA;;;;ACbrB;;AAEG;;;;"}
|
|
@@ -2,16 +2,14 @@ import { __awaiter } from 'tslib';
|
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
3
|
import { Injectable } from '@angular/core';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
|
-
import { scan, map, distinctUntilChanged, delay } from 'rxjs/operators';
|
|
5
|
+
import { scan, map, tap, distinctUntilChanged, shareReplay, delay } from 'rxjs/operators';
|
|
6
6
|
|
|
7
7
|
class LoadingService {
|
|
8
8
|
constructor() {
|
|
9
9
|
this.loadingEntries$ = new Subject();
|
|
10
|
-
this.loadingMap =
|
|
11
|
-
this.loadingMap$ = this.loadingEntries$.pipe(scan((
|
|
12
|
-
|
|
13
|
-
.reduce((p, [k, v]) => (Object.assign(Object.assign({}, p), { [k]: v })), {})), distinctUntilChanged((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur)));
|
|
14
|
-
this.isLoading$ = this.loadingMap$.pipe(map((m) => !!Object.keys(m).length), delay(0));
|
|
10
|
+
this.loadingMap = new Map();
|
|
11
|
+
this.loadingMap$ = this.loadingEntries$.pipe(scan((map, [key, value]) => map.set(key, value), new Map()), map((map) => new Map([...map.entries()].filter(([_, v]) => v))), tap(m => console.debug('m:', m)), distinctUntilChanged((pre, cur) => JSON.stringify([...pre.entries()]) === JSON.stringify([...cur.entries()])), shareReplay(1));
|
|
12
|
+
this.isLoading$ = this.loadingMap$.pipe(map((map) => !![...map.keys()].length), delay(0));
|
|
15
13
|
this.loadingMap$.subscribe((m) => {
|
|
16
14
|
this.loadingMap = m;
|
|
17
15
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-services-loading.mjs","sources":["../../../../../packages/@ng-atomic/common/src/services/loading/loading.service.ts","../../../../../packages/@ng-atomic/common/src/services/loading/ng-atomic-common-services-loading.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { scan, map, distinctUntilChanged, delay } from 'rxjs/operators';\n\ntype LoadingMap =
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-services-loading.mjs","sources":["../../../../../packages/@ng-atomic/common/src/services/loading/loading.service.ts","../../../../../packages/@ng-atomic/common/src/services/loading/ng-atomic-common-services-loading.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { scan, map, distinctUntilChanged, delay, tap, shareReplay } from 'rxjs/operators';\n\ntype LoadingMap = Map<string, boolean>;\n\n@Injectable({\n providedIn: 'root',\n})\nexport class LoadingService {\n private loadingEntries$ = new Subject<[string, boolean]>();\n\n loadingMap: LoadingMap = new Map();\n loadingMap$ = this.loadingEntries$.pipe(\n scan((map, [key, value]) => map.set(key, value), new Map()),\n map((map: LoadingMap) => new Map([...map.entries()].filter(([_, v]: [string, boolean]) => v))),\n tap(m => console.debug('m:', m)),\n distinctUntilChanged((pre, cur) => JSON.stringify([...pre.entries()]) === JSON.stringify([...cur.entries()])),\n shareReplay(1),\n );\n\n isLoading$ = this.loadingMap$.pipe(\n map((map) => !![...map.keys()].length),\n delay(0),\n );\n\n constructor() {\n this.loadingMap$.subscribe((m) => {\n this.loadingMap = m;\n });\n }\n\n setKey(key: string): void {\n this.loadingEntries$.next([key, true]);\n }\n\n removeKey(key: string): void {\n this.loadingEntries$.next([key, false]);\n }\n\n start(callback: (done: any) => void, key: string = randomStr(16)) {\n this.setKey(key);\n callback(() => this.removeKey(key));\n }\n\n async await(callback: (...args: any[]) => Promise<void>) {\n const key = randomStr(16);\n this.setKey(key);\n await callback();\n this.removeKey(key);\n }\n}\n\nexport function randomStr(n: number = 16): string {\n return Math.random().toString(36).substr(2, n);\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -12,6 +12,7 @@ class EntitiesStore extends ComponentStore {
|
|
|
12
12
|
super(initialState);
|
|
13
13
|
this.refresh$ = new ReplaySubject(1);
|
|
14
14
|
this.entities$ = this.select(({ entities }) => entities ? entities.sort(compareById) : []);
|
|
15
|
+
this.size$ = this.select(({ entities }) => { var _a; return (_a = entities === null || entities === void 0 ? void 0 : entities.length) !== null && _a !== void 0 ? _a : 0; });
|
|
15
16
|
this.setEntities = this.updater((state, entities) => (Object.assign(Object.assign({}, state), { entities })));
|
|
16
17
|
this.refresh();
|
|
17
18
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-stores-entities.mjs","sources":["../../../../../packages/@ng-atomic/common/src/stores/entities/entities.store.ts","../../../../../packages/@ng-atomic/common/src/stores/entities/ng-atomic-common-stores-entities.ts"],"sourcesContent":["import { ComponentStore } from '@ngrx/component-store';\nimport { compareById } from '@ng-atomic/common/utils';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { distinctUntilChanged, tap, filter, switchMap } from 'rxjs/operators';\n\nexport interface EntitiesState<E> {\n entities: E[]\n}\n\nexport const distinctUntilChangedArray = <T>() => {\n return distinctUntilChanged<T>((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur));\n};\n\nexport abstract class EntitiesStore<
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-stores-entities.mjs","sources":["../../../../../packages/@ng-atomic/common/src/stores/entities/entities.store.ts","../../../../../packages/@ng-atomic/common/src/stores/entities/ng-atomic-common-stores-entities.ts"],"sourcesContent":["import { ComponentStore } from '@ngrx/component-store';\nimport { compareById } from '@ng-atomic/common/utils';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { distinctUntilChanged, tap, filter, switchMap } from 'rxjs/operators';\n\nexport interface EntitiesState<E> {\n entities: E[]\n}\n\nexport const distinctUntilChangedArray = <T>() => {\n return distinctUntilChanged<T>((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur));\n};\n\nexport abstract class EntitiesStore<E extends {id: string}, S extends EntitiesState<E> = any> extends ComponentStore<S> {\n protected readonly refresh$ = new ReplaySubject<void>(1);\n\n get entities() { return this.get().entities; }\n\n entities$ = this.select(({entities}) => entities ? entities.sort(compareById) : []);\n size$ = this.select(({entities}) => entities?.length ?? 0);\n \n constructor(initialState: S) {\n super(initialState);\n this.refresh();\n }\n\n setEntities = this.updater((state, entities: E[]) => ({...state, entities}));\n\n abstract getEntities: ReturnType<typeof this.effect>;\n\n refresh() {\n this.refresh$.next();\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;AASO,MAAM,yBAAyB,GAAG,MAAQ;IAC/C,OAAO,oBAAoB,CAAI,CAAC,GAAG,EAAE,GAAG,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;AAC5F,EAAE;AAEI,MAAgB,aAAwE,SAAQ,cAAiB,CAAA;IAGrH,IAAI,QAAQ,GAAK,EAAA,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE;AAK9C,IAAA,WAAA,CAAY,YAAe,EAAA;QACzB,KAAK,CAAC,YAAY,CAAC,CAAC;QARH,IAAA,CAAA,QAAQ,GAAG,IAAI,aAAa,CAAO,CAAC,CAAC,CAAC;AAIzD,QAAA,IAAS,CAAA,SAAA,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAC,QAAQ,EAAC,KAAK,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,CAAC;AACpF,QAAA,IAAA,CAAA,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAC,QAAQ,EAAC,KAAI,EAAA,IAAA,EAAA,CAAA,CAAC,OAAA,CAAA,EAAA,GAAA,QAAQ,KAAA,IAAA,IAAR,QAAQ,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAR,QAAQ,CAAE,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,CAAC,CAAA,EAAA,CAAC,CAAC;QAO3D,IAAW,CAAA,WAAA,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,QAAa,MAAU,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,KAAK,KAAE,QAAQ,EAAA,CAAA,CAAE,CAAC,CAAC;QAH3E,IAAI,CAAC,OAAO,EAAE,CAAC;KAChB;IAMD,OAAO,GAAA;AACL,QAAA,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;KACtB;AACF;;ACjCD;;AAEG;;;;"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { InjectionToken, Pipe, Inject } from '@angular/core';
|
|
3
|
+
|
|
4
|
+
const SELECT_ID = new InjectionToken('[@ng-atomic/common] Select Id');
|
|
5
|
+
const defaultSelectId = (entity) => entity.Id;
|
|
6
|
+
class SelectIdPipe {
|
|
7
|
+
constructor(selectId) {
|
|
8
|
+
this.selectId = selectId;
|
|
9
|
+
}
|
|
10
|
+
transform(entity) {
|
|
11
|
+
return this.selectId(entity);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
SelectIdPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, deps: [{ token: SELECT_ID }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
15
|
+
SelectIdPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, isStandalone: true, name: "selectId" });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: SelectIdPipe, decorators: [{
|
|
17
|
+
type: Pipe,
|
|
18
|
+
args: [{
|
|
19
|
+
name: 'selectId',
|
|
20
|
+
pure: true,
|
|
21
|
+
standalone: true,
|
|
22
|
+
}]
|
|
23
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
24
|
+
type: Inject,
|
|
25
|
+
args: [SELECT_ID]
|
|
26
|
+
}] }]; } });
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Generated bundle index. Do not edit.
|
|
30
|
+
*/
|
|
31
|
+
|
|
32
|
+
export { SELECT_ID, SelectIdPipe, defaultSelectId };
|
|
33
|
+
//# sourceMappingURL=ng-atomic-common-pipes-select-id.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-pipes-select-id.mjs","sources":["../../../../../packages/@ng-atomic/common/src/pipes/select-id/select-id.pipe.ts","../../../../../packages/@ng-atomic/common/src/pipes/select-id/ng-atomic-common-pipes-select-id.ts"],"sourcesContent":["import { Inject, InjectionToken, Pipe } from \"@angular/core\";\n\nexport type SelectId = (entity: object) => string | number;\nexport const SELECT_ID = new InjectionToken<SelectId>('[@ng-atomic/common] Select Id');\nexport const defaultSelectId: SelectId = (entity: any) => entity.Id;\n\n@Pipe({\n name: 'selectId',\n pure: true,\n standalone: true,\n})\nexport class SelectIdPipe {\n constructor(\n @Inject(SELECT_ID) protected selectId: SelectId\n ) {}\n\n transform(entity: any): string | number {\n return this.selectId(entity);\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;MAGa,SAAS,GAAG,IAAI,cAAc,CAAW,+BAA+B,EAAE;AAChF,MAAM,eAAe,GAAa,CAAC,MAAW,KAAK,MAAM,CAAC,GAAG;MAOvD,YAAY,CAAA;AACvB,IAAA,WAAA,CAC+B,QAAkB,EAAA;QAAlB,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAU;KAC7C;AAEJ,IAAA,SAAS,CAAC,MAAW,EAAA;AACnB,QAAA,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;KAC9B;;AAPU,YAAA,CAAA,IAAA,GAAA,EAAA,CAAA,kBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,YAAY,kBAEb,SAAS,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,IAAA,EAAA,CAAA,CAAA;uGAFR,YAAY,EAAA,YAAA,EAAA,IAAA,EAAA,IAAA,EAAA,UAAA,EAAA,CAAA,CAAA;2FAAZ,YAAY,EAAA,UAAA,EAAA,CAAA;kBALxB,IAAI;AAAC,YAAA,IAAA,EAAA,CAAA;AACJ,oBAAA,IAAI,EAAE,UAAU;AAChB,oBAAA,IAAI,EAAE,IAAI;AACV,oBAAA,UAAU,EAAE,IAAI;AACjB,iBAAA,CAAA;;0BAGI,MAAM;2BAAC,SAAS,CAAA;;;ACbrB;;AAEG;;;;"}
|
|
@@ -1,16 +1,14 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { Injectable } from '@angular/core';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
|
-
import { scan, map, distinctUntilChanged, delay } from 'rxjs/operators';
|
|
4
|
+
import { scan, map, tap, distinctUntilChanged, shareReplay, delay } from 'rxjs/operators';
|
|
5
5
|
|
|
6
6
|
class LoadingService {
|
|
7
7
|
constructor() {
|
|
8
8
|
this.loadingEntries$ = new Subject();
|
|
9
|
-
this.loadingMap =
|
|
10
|
-
this.loadingMap$ = this.loadingEntries$.pipe(scan((
|
|
11
|
-
|
|
12
|
-
.reduce((p, [k, v]) => ({ ...p, [k]: v }), {})), distinctUntilChanged((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur)));
|
|
13
|
-
this.isLoading$ = this.loadingMap$.pipe(map((m) => !!Object.keys(m).length), delay(0));
|
|
9
|
+
this.loadingMap = new Map();
|
|
10
|
+
this.loadingMap$ = this.loadingEntries$.pipe(scan((map, [key, value]) => map.set(key, value), new Map()), map((map) => new Map([...map.entries()].filter(([_, v]) => v))), tap(m => console.debug('m:', m)), distinctUntilChanged((pre, cur) => JSON.stringify([...pre.entries()]) === JSON.stringify([...cur.entries()])), shareReplay(1));
|
|
11
|
+
this.isLoading$ = this.loadingMap$.pipe(map((map) => !![...map.keys()].length), delay(0));
|
|
14
12
|
this.loadingMap$.subscribe((m) => {
|
|
15
13
|
this.loadingMap = m;
|
|
16
14
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-services-loading.mjs","sources":["../../../../../packages/@ng-atomic/common/src/services/loading/loading.service.ts","../../../../../packages/@ng-atomic/common/src/services/loading/ng-atomic-common-services-loading.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { scan, map, distinctUntilChanged, delay } from 'rxjs/operators';\n\ntype LoadingMap =
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-services-loading.mjs","sources":["../../../../../packages/@ng-atomic/common/src/services/loading/loading.service.ts","../../../../../packages/@ng-atomic/common/src/services/loading/ng-atomic-common-services-loading.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { scan, map, distinctUntilChanged, delay, tap, shareReplay } from 'rxjs/operators';\n\ntype LoadingMap = Map<string, boolean>;\n\n@Injectable({\n providedIn: 'root',\n})\nexport class LoadingService {\n private loadingEntries$ = new Subject<[string, boolean]>();\n\n loadingMap: LoadingMap = new Map();\n loadingMap$ = this.loadingEntries$.pipe(\n scan((map, [key, value]) => map.set(key, value), new Map()),\n map((map: LoadingMap) => new Map([...map.entries()].filter(([_, v]: [string, boolean]) => v))),\n tap(m => console.debug('m:', m)),\n distinctUntilChanged((pre, cur) => JSON.stringify([...pre.entries()]) === JSON.stringify([...cur.entries()])),\n shareReplay(1),\n );\n\n isLoading$ = this.loadingMap$.pipe(\n map((map) => !![...map.keys()].length),\n delay(0),\n );\n\n constructor() {\n this.loadingMap$.subscribe((m) => {\n this.loadingMap = m;\n });\n }\n\n setKey(key: string): void {\n this.loadingEntries$.next([key, true]);\n }\n\n removeKey(key: string): void {\n this.loadingEntries$.next([key, false]);\n }\n\n start(callback: (done: any) => void, key: string = randomStr(16)) {\n this.setKey(key);\n callback(() => this.removeKey(key));\n }\n\n async await(callback: (...args: any[]) => Promise<void>) {\n const key = randomStr(16);\n this.setKey(key);\n await callback();\n this.removeKey(key);\n }\n}\n\nexport function randomStr(n: number = 16): string {\n return Math.random().toString(36).substr(2, n);\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -12,6 +12,7 @@ class EntitiesStore extends ComponentStore {
|
|
|
12
12
|
super(initialState);
|
|
13
13
|
this.refresh$ = new ReplaySubject(1);
|
|
14
14
|
this.entities$ = this.select(({ entities }) => entities ? entities.sort(compareById) : []);
|
|
15
|
+
this.size$ = this.select(({ entities }) => entities?.length ?? 0);
|
|
15
16
|
this.setEntities = this.updater((state, entities) => ({ ...state, entities }));
|
|
16
17
|
this.refresh();
|
|
17
18
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-common-stores-entities.mjs","sources":["../../../../../packages/@ng-atomic/common/src/stores/entities/entities.store.ts","../../../../../packages/@ng-atomic/common/src/stores/entities/ng-atomic-common-stores-entities.ts"],"sourcesContent":["import { ComponentStore } from '@ngrx/component-store';\nimport { compareById } from '@ng-atomic/common/utils';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { distinctUntilChanged, tap, filter, switchMap } from 'rxjs/operators';\n\nexport interface EntitiesState<E> {\n entities: E[]\n}\n\nexport const distinctUntilChangedArray = <T>() => {\n return distinctUntilChanged<T>((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur));\n};\n\nexport abstract class EntitiesStore<
|
|
1
|
+
{"version":3,"file":"ng-atomic-common-stores-entities.mjs","sources":["../../../../../packages/@ng-atomic/common/src/stores/entities/entities.store.ts","../../../../../packages/@ng-atomic/common/src/stores/entities/ng-atomic-common-stores-entities.ts"],"sourcesContent":["import { ComponentStore } from '@ngrx/component-store';\nimport { compareById } from '@ng-atomic/common/utils';\nimport { Observable, ReplaySubject } from 'rxjs';\nimport { distinctUntilChanged, tap, filter, switchMap } from 'rxjs/operators';\n\nexport interface EntitiesState<E> {\n entities: E[]\n}\n\nexport const distinctUntilChangedArray = <T>() => {\n return distinctUntilChanged<T>((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur));\n};\n\nexport abstract class EntitiesStore<E extends {id: string}, S extends EntitiesState<E> = any> extends ComponentStore<S> {\n protected readonly refresh$ = new ReplaySubject<void>(1);\n\n get entities() { return this.get().entities; }\n\n entities$ = this.select(({entities}) => entities ? entities.sort(compareById) : []);\n size$ = this.select(({entities}) => entities?.length ?? 0);\n \n constructor(initialState: S) {\n super(initialState);\n this.refresh();\n }\n\n setEntities = this.updater((state, entities: E[]) => ({...state, entities}));\n\n abstract getEntities: ReturnType<typeof this.effect>;\n\n refresh() {\n this.refresh$.next();\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;AASO,MAAM,yBAAyB,GAAG,MAAQ;IAC/C,OAAO,oBAAoB,CAAI,CAAC,GAAG,EAAE,GAAG,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;AAC5F,EAAE;AAEI,MAAgB,aAAwE,SAAQ,cAAiB,CAAA;IAGrH,IAAI,QAAQ,GAAK,EAAA,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE;AAK9C,IAAA,WAAA,CAAY,YAAe,EAAA;QACzB,KAAK,CAAC,YAAY,CAAC,CAAC;AARH,QAAA,IAAA,CAAA,QAAQ,GAAG,IAAI,aAAa,CAAO,CAAC,CAAC,CAAC;QAIzD,IAAS,CAAA,SAAA,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAC,QAAQ,EAAC,KAAK,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,CAAC;AACpF,QAAA,IAAA,CAAA,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAC,QAAQ,EAAC,KAAK,QAAQ,EAAE,MAAM,IAAI,CAAC,CAAC,CAAC;QAO3D,IAAW,CAAA,WAAA,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,QAAa,MAAM,EAAC,GAAG,KAAK,EAAE,QAAQ,EAAC,CAAC,CAAC,CAAC;QAH3E,IAAI,CAAC,OAAO,EAAE,CAAC;KAChB;IAMD,OAAO,GAAA;AACL,QAAA,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;KACtB;AACF;;ACjCD;;AAEG;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ng-atomic/common",
|
|
3
|
-
"version": "5.
|
|
3
|
+
"version": "5.10.0",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"module": "fesm2015/ng-atomic-common.mjs",
|
|
6
6
|
"es2020": "fesm2020/ng-atomic-common.mjs",
|
|
@@ -60,6 +60,14 @@
|
|
|
60
60
|
"node": "./fesm2015/ng-atomic-common-pipes-pagination.mjs",
|
|
61
61
|
"default": "./fesm2020/ng-atomic-common-pipes-pagination.mjs"
|
|
62
62
|
},
|
|
63
|
+
"./pipes/select-id": {
|
|
64
|
+
"types": "./pipes/select-id/index.d.ts",
|
|
65
|
+
"esm2020": "./esm2020/pipes/select-id/ng-atomic-common-pipes-select-id.mjs",
|
|
66
|
+
"es2020": "./fesm2020/ng-atomic-common-pipes-select-id.mjs",
|
|
67
|
+
"es2015": "./fesm2015/ng-atomic-common-pipes-select-id.mjs",
|
|
68
|
+
"node": "./fesm2015/ng-atomic-common-pipes-select-id.mjs",
|
|
69
|
+
"default": "./fesm2020/ng-atomic-common-pipes-select-id.mjs"
|
|
70
|
+
},
|
|
63
71
|
"./pipes/smart-exp": {
|
|
64
72
|
"types": "./pipes/smart-exp/index.d.ts",
|
|
65
73
|
"esm2020": "./esm2020/pipes/smart-exp/ng-atomic-common-pipes-smart-exp.mjs",
|
|
@@ -204,10 +212,10 @@
|
|
|
204
212
|
"peerDependencies": {
|
|
205
213
|
"@angular/core": "^15.0.0",
|
|
206
214
|
"@angular/common": "^15.0.0",
|
|
215
|
+
"rxjs": "^7.0.0",
|
|
207
216
|
"lodash": "4.17.21",
|
|
208
217
|
"dayjs": "1.11.7",
|
|
209
218
|
"flat": "^5.0.2",
|
|
210
|
-
"rxjs": "^7.0.0",
|
|
211
219
|
"@angular/material": "^15.0.0"
|
|
212
220
|
}
|
|
213
221
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './select-id.pipe';
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { InjectionToken } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export type SelectId = (entity: object) => string | number;
|
|
4
|
+
export declare const SELECT_ID: InjectionToken<SelectId>;
|
|
5
|
+
export declare const defaultSelectId: SelectId;
|
|
6
|
+
export declare class SelectIdPipe {
|
|
7
|
+
protected selectId: SelectId;
|
|
8
|
+
constructor(selectId: SelectId);
|
|
9
|
+
transform(entity: any): string | number;
|
|
10
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SelectIdPipe, never>;
|
|
11
|
+
static ɵpipe: i0.ɵɵPipeDeclaration<SelectIdPipe, "selectId", true>;
|
|
12
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
|
-
type LoadingMap =
|
|
2
|
+
type LoadingMap = Map<string, boolean>;
|
|
3
3
|
export declare class LoadingService {
|
|
4
4
|
private loadingEntries$;
|
|
5
5
|
loadingMap: LoadingMap;
|
|
6
|
-
loadingMap$: import("rxjs").Observable<
|
|
6
|
+
loadingMap$: import("rxjs").Observable<Map<string, boolean>>;
|
|
7
7
|
isLoading$: import("rxjs").Observable<boolean>;
|
|
8
8
|
constructor();
|
|
9
9
|
setKey(key: string): void;
|
|
@@ -4,12 +4,13 @@ export interface EntitiesState<E> {
|
|
|
4
4
|
entities: E[];
|
|
5
5
|
}
|
|
6
6
|
export declare const distinctUntilChangedArray: <T>() => import("rxjs").MonoTypeOperatorFunction<T>;
|
|
7
|
-
export declare abstract class EntitiesStore<
|
|
7
|
+
export declare abstract class EntitiesStore<E extends {
|
|
8
8
|
id: string;
|
|
9
|
-
} = any> extends ComponentStore<S> {
|
|
9
|
+
}, S extends EntitiesState<E> = any> extends ComponentStore<S> {
|
|
10
10
|
protected readonly refresh$: ReplaySubject<void>;
|
|
11
11
|
get entities(): E[];
|
|
12
12
|
entities$: Observable<E[]>;
|
|
13
|
+
size$: Observable<number>;
|
|
13
14
|
constructor(initialState: S);
|
|
14
15
|
setEntities: (observableOrValue: E[] | Observable<E[]>) => import("rxjs").Subscription;
|
|
15
16
|
abstract getEntities: ReturnType<typeof this.effect>;
|