@webiny/app-utils 6.0.0-alpha.5 → 6.0.0-rc.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/README.md +6 -13
- package/features/List/FilterFeature.d.ts +11 -0
- package/features/List/FilterFeature.js +25 -0
- package/features/List/FilterFeature.js.map +1 -0
- package/features/List/ListQueryParamsRepository.d.ts +18 -0
- package/features/List/ListQueryParamsRepository.js +70 -0
- package/features/List/ListQueryParamsRepository.js.map +1 -0
- package/features/List/LoadMoreFeature.d.ts +13 -0
- package/features/List/LoadMoreFeature.js +30 -0
- package/features/List/LoadMoreFeature.js.map +1 -0
- package/features/List/LoadingRepository.d.ts +15 -0
- package/features/List/LoadingRepository.js +50 -0
- package/features/List/LoadingRepository.js.map +1 -0
- package/features/List/SearchFeature.d.ts +10 -0
- package/features/List/SearchFeature.js +17 -0
- package/features/List/SearchFeature.js.map +1 -0
- package/features/List/SortFeature.d.ts +10 -0
- package/features/List/SortFeature.js +20 -0
- package/features/List/SortFeature.js.map +1 -0
- package/features/List/abstractions.d.ts +73 -0
- package/features/List/abstractions.js +34 -0
- package/features/List/abstractions.js.map +1 -0
- package/features/List/feature.d.ts +8 -0
- package/features/List/feature.js +34 -0
- package/features/List/feature.js.map +1 -0
- package/fta/Domain/Models/Meta/MetaMapper.d.ts +1 -1
- package/fta/Domain/Models/Meta/MetaMapper.js.map +1 -1
- package/fta/Domain/Models/Meta/index.d.ts +2 -2
- package/fta/Domain/Models/Meta/index.js +2 -2
- package/fta/Domain/Models/Meta/index.js.map +1 -1
- package/fta/Domain/Models/Sorting/SortingMapper.d.ts +1 -1
- package/fta/Domain/Models/Sorting/SortingMapper.js.map +1 -1
- package/fta/Domain/Models/Sorting/index.d.ts +2 -2
- package/fta/Domain/Models/Sorting/index.js +2 -2
- package/fta/Domain/Models/Sorting/index.js.map +1 -1
- package/fta/Domain/Models/index.d.ts +2 -2
- package/fta/Domain/Models/index.js +2 -2
- package/fta/Domain/Models/index.js.map +1 -1
- package/fta/Domain/Repositories/Loading/ILoadingRepository.d.ts +1 -0
- package/fta/Domain/Repositories/Loading/ILoadingRepository.js.map +1 -1
- package/fta/Domain/Repositories/Loading/LoadingRepository.d.ts +1 -1
- package/fta/Domain/Repositories/Loading/LoadingRepository.js +8 -3
- package/fta/Domain/Repositories/Loading/LoadingRepository.js.map +1 -1
- package/fta/Domain/Repositories/Loading/LoadingRepositoryFactory.d.ts +1 -1
- package/fta/Domain/Repositories/Loading/LoadingRepositoryFactory.js +1 -1
- package/fta/Domain/Repositories/Loading/LoadingRepositoryFactory.js.map +1 -1
- package/fta/Domain/Repositories/Loading/index.d.ts +3 -3
- package/fta/Domain/Repositories/Loading/index.js +2 -3
- package/fta/Domain/Repositories/Loading/index.js.map +1 -1
- package/fta/Domain/Repositories/Meta/IMetaRepository.d.ts +1 -1
- package/fta/Domain/Repositories/Meta/IMetaRepository.js.map +1 -1
- package/fta/Domain/Repositories/Meta/MetaRepository.d.ts +2 -2
- package/fta/Domain/Repositories/Meta/MetaRepository.js +1 -1
- package/fta/Domain/Repositories/Meta/MetaRepository.js.map +1 -1
- package/fta/Domain/Repositories/Meta/MetaRepositoryFactory.d.ts +1 -1
- package/fta/Domain/Repositories/Meta/MetaRepositoryFactory.js +1 -1
- package/fta/Domain/Repositories/Meta/MetaRepositoryFactory.js.map +1 -1
- package/fta/Domain/Repositories/Meta/index.d.ts +3 -3
- package/fta/Domain/Repositories/Meta/index.js +2 -3
- package/fta/Domain/Repositories/Meta/index.js.map +1 -1
- package/fta/Domain/Repositories/Sorting/ISortingRepository.d.ts +1 -1
- package/fta/Domain/Repositories/Sorting/ISortingRepository.js.map +1 -1
- package/fta/Domain/Repositories/Sorting/SortingRepository.d.ts +2 -2
- package/fta/Domain/Repositories/Sorting/SortingRepository.js.map +1 -1
- package/fta/Domain/Repositories/Sorting/SortingRepositoryFactory.d.ts +1 -1
- package/fta/Domain/Repositories/Sorting/SortingRepositoryFactory.js +1 -1
- package/fta/Domain/Repositories/Sorting/SortingRepositoryFactory.js.map +1 -1
- package/fta/Domain/Repositories/Sorting/index.d.ts +3 -3
- package/fta/Domain/Repositories/Sorting/index.js +2 -3
- package/fta/Domain/Repositories/Sorting/index.js.map +1 -1
- package/fta/Domain/Repositories/index.d.ts +3 -3
- package/fta/Domain/Repositories/index.js +3 -3
- package/fta/Domain/Repositories/index.js.map +1 -1
- package/fta/Domain/index.d.ts +2 -2
- package/fta/Domain/index.js +2 -2
- package/fta/Domain/index.js.map +1 -1
- package/fta/index.d.ts +1 -1
- package/fta/index.js +1 -1
- package/fta/index.js.map +1 -1
- package/index.d.ts +1 -1
- package/index.js +1 -1
- package/index.js.map +1 -1
- package/package.json +8 -10
package/README.md
CHANGED
|
@@ -1,18 +1,11 @@
|
|
|
1
1
|
# @webiny/app-utils
|
|
2
2
|
|
|
3
|
-
[!
|
|
4
|
-
[
|
|
5
|
-
|
|
6
|
-
[](http://makeapullrequest.com)
|
|
3
|
+
> [!NOTE]
|
|
4
|
+
> This package is part of the [Webiny](https://www.webiny.com) monorepo.
|
|
5
|
+
> It’s **included in every Webiny project by default** and is not meant to be used as a standalone package.
|
|
7
6
|
|
|
8
|
-
|
|
7
|
+
📘 **Documentation:** [https://www.webiny.com/docs](https://www.webiny.com/docs)
|
|
9
8
|
|
|
10
|
-
|
|
11
|
-
npm install --save @webiny/app-utils
|
|
12
|
-
```
|
|
9
|
+
---
|
|
13
10
|
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
```
|
|
17
|
-
yarn add @webiny/app-utils
|
|
18
|
-
```
|
|
11
|
+
_This README file is automatically generated during the publish process._
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { type IFilterFeature, ListQueryParamsRepository, type BaseListParams } from "./abstractions.js";
|
|
2
|
+
declare class FilterFeatureImpl<TParams extends BaseListParams> implements IFilterFeature {
|
|
3
|
+
private queryParams;
|
|
4
|
+
constructor(queryParams: ListQueryParamsRepository.Interface<TParams>);
|
|
5
|
+
setFilter(key: string, value: unknown): Promise<void>;
|
|
6
|
+
clearAllFilters(): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare const FilterFeature: typeof FilterFeatureImpl & {
|
|
9
|
+
__abstraction: import("@webiny/di").Abstraction<IFilterFeature>;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { FilterFeature as Abstraction, ListQueryParamsRepository } from "./abstractions.js";
|
|
2
|
+
class FilterFeatureImpl {
|
|
3
|
+
constructor(queryParams) {
|
|
4
|
+
this.queryParams = queryParams;
|
|
5
|
+
}
|
|
6
|
+
async setFilter(key, value) {
|
|
7
|
+
await this.queryParams.set(params => {
|
|
8
|
+
if (!params.filters) {
|
|
9
|
+
params.filters = {};
|
|
10
|
+
}
|
|
11
|
+
params.filters[key] = value;
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
async clearAllFilters() {
|
|
15
|
+
await this.queryParams.set(params => {
|
|
16
|
+
params.filters = {};
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export const FilterFeature = Abstraction.createImplementation({
|
|
21
|
+
implementation: FilterFeatureImpl,
|
|
22
|
+
dependencies: [ListQueryParamsRepository]
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
//# sourceMappingURL=FilterFeature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["FilterFeature","Abstraction","ListQueryParamsRepository","FilterFeatureImpl","constructor","queryParams","setFilter","key","value","set","params","filters","clearAllFilters","createImplementation","implementation","dependencies"],"sources":["FilterFeature.ts"],"sourcesContent":["import {\n FilterFeature as Abstraction,\n type IFilterFeature,\n ListQueryParamsRepository,\n type BaseListParams\n} from \"./abstractions.js\";\n\nclass FilterFeatureImpl<TParams extends BaseListParams> implements IFilterFeature {\n constructor(private queryParams: ListQueryParamsRepository.Interface<TParams>) {}\n\n async setFilter(key: string, value: unknown): Promise<void> {\n await this.queryParams.set(params => {\n if (!params.filters) {\n params.filters = {};\n }\n params.filters[key] = value;\n });\n }\n\n async clearAllFilters(): Promise<void> {\n await this.queryParams.set(params => {\n params.filters = {};\n });\n }\n}\n\nexport const FilterFeature = Abstraction.createImplementation({\n implementation: FilterFeatureImpl,\n dependencies: [ListQueryParamsRepository]\n});\n"],"mappings":"AAAA,SACIA,aAAa,IAAIC,WAAW,EAE5BC,yBAAyB;AAI7B,MAAMC,iBAAiB,CAA2D;EAC9EC,WAAWA,CAASC,WAAyD,EAAE;IAAA,KAA3DA,WAAyD,GAAzDA,WAAyD;EAAG;EAEhF,MAAMC,SAASA,CAACC,GAAW,EAAEC,KAAc,EAAiB;IACxD,MAAM,IAAI,CAACH,WAAW,CAACI,GAAG,CAACC,MAAM,IAAI;MACjC,IAAI,CAACA,MAAM,CAACC,OAAO,EAAE;QACjBD,MAAM,CAACC,OAAO,GAAG,CAAC,CAAC;MACvB;MACAD,MAAM,CAACC,OAAO,CAACJ,GAAG,CAAC,GAAGC,KAAK;IAC/B,CAAC,CAAC;EACN;EAEA,MAAMI,eAAeA,CAAA,EAAkB;IACnC,MAAM,IAAI,CAACP,WAAW,CAACI,GAAG,CAACC,MAAM,IAAI;MACjCA,MAAM,CAACC,OAAO,GAAG,CAAC,CAAC;IACvB,CAAC,CAAC;EACN;AACJ;AAEA,OAAO,MAAMX,aAAa,GAAGC,WAAW,CAACY,oBAAoB,CAAC;EAC1DC,cAAc,EAAEX,iBAAiB;EACjCY,YAAY,EAAE,CAACb,yBAAyB;AAC5C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { type BaseListParams, type IListQueryParamsRepository } from "./abstractions.js";
|
|
2
|
+
export declare class ListQueryParamsRepositoryImpl<TParams extends BaseListParams> implements IListQueryParamsRepository<TParams> {
|
|
3
|
+
private params;
|
|
4
|
+
private readonly initial;
|
|
5
|
+
private readonly listeners;
|
|
6
|
+
constructor();
|
|
7
|
+
get(): TParams;
|
|
8
|
+
set(updater: (params: TParams) => void): Promise<void>;
|
|
9
|
+
replace(next: TParams): Promise<void>;
|
|
10
|
+
reset(): void;
|
|
11
|
+
subscribe(listener: (next: TParams) => void): () => void;
|
|
12
|
+
dispose(): void;
|
|
13
|
+
private notify;
|
|
14
|
+
private clone;
|
|
15
|
+
}
|
|
16
|
+
export declare const ListQueryParamsRepository: typeof ListQueryParamsRepositoryImpl & {
|
|
17
|
+
__abstraction: import("@webiny/di").Abstraction<IListQueryParamsRepository<any>>;
|
|
18
|
+
};
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { makeAutoObservable, runInAction } from "mobx";
|
|
2
|
+
import { ListQueryParamsRepository as Abstraction } from "./abstractions.js";
|
|
3
|
+
export class ListQueryParamsRepositoryImpl {
|
|
4
|
+
listeners = new Set();
|
|
5
|
+
constructor() {
|
|
6
|
+
this.initial = {
|
|
7
|
+
search: "",
|
|
8
|
+
sort: [],
|
|
9
|
+
filters: {},
|
|
10
|
+
limit: 50
|
|
11
|
+
};
|
|
12
|
+
this.params = this.clone(this.initial);
|
|
13
|
+
makeAutoObservable(this, {
|
|
14
|
+
subscribe: false,
|
|
15
|
+
dispose: false
|
|
16
|
+
}, {
|
|
17
|
+
autoBind: true
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
get() {
|
|
21
|
+
return this.clone(this.params);
|
|
22
|
+
}
|
|
23
|
+
async set(updater) {
|
|
24
|
+
runInAction(() => {
|
|
25
|
+
updater(this.params);
|
|
26
|
+
});
|
|
27
|
+
this.notify();
|
|
28
|
+
}
|
|
29
|
+
async replace(next) {
|
|
30
|
+
runInAction(() => {
|
|
31
|
+
this.params = this.clone(next);
|
|
32
|
+
});
|
|
33
|
+
this.notify();
|
|
34
|
+
}
|
|
35
|
+
reset() {
|
|
36
|
+
runInAction(() => {
|
|
37
|
+
this.params = this.clone(this.initial);
|
|
38
|
+
});
|
|
39
|
+
this.notify();
|
|
40
|
+
}
|
|
41
|
+
subscribe(listener) {
|
|
42
|
+
this.listeners.add(listener);
|
|
43
|
+
return () => {
|
|
44
|
+
this.listeners.delete(listener);
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
dispose() {
|
|
48
|
+
this.listeners.clear();
|
|
49
|
+
}
|
|
50
|
+
notify() {
|
|
51
|
+
const snap = this.clone(this.params);
|
|
52
|
+
for (const listener of this.listeners) {
|
|
53
|
+
try {
|
|
54
|
+
listener(snap);
|
|
55
|
+
} catch (error) {
|
|
56
|
+
// Swallow listener errors to prevent cascading failures
|
|
57
|
+
console.error("Error in ListQueryParams listener:", error);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
clone(value) {
|
|
62
|
+
return structuredClone ? structuredClone(value) : JSON.parse(JSON.stringify(value));
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
export const ListQueryParamsRepository = Abstraction.createImplementation({
|
|
66
|
+
implementation: ListQueryParamsRepositoryImpl,
|
|
67
|
+
dependencies: []
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
//# sourceMappingURL=ListQueryParamsRepository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["makeAutoObservable","runInAction","ListQueryParamsRepository","Abstraction","ListQueryParamsRepositoryImpl","listeners","Set","constructor","initial","search","sort","filters","limit","params","clone","subscribe","dispose","autoBind","get","set","updater","notify","replace","next","reset","listener","add","delete","clear","snap","error","console","value","structuredClone","JSON","parse","stringify","createImplementation","implementation","dependencies"],"sources":["ListQueryParamsRepository.ts"],"sourcesContent":["import { makeAutoObservable, runInAction } from \"mobx\";\nimport {\n ListQueryParamsRepository as Abstraction,\n type BaseListParams,\n type IListQueryParamsRepository\n} from \"./abstractions.js\";\n\nexport class ListQueryParamsRepositoryImpl<TParams extends BaseListParams>\n implements IListQueryParamsRepository<TParams>\n{\n private params: TParams;\n private readonly initial: TParams;\n private readonly listeners = new Set<(next: TParams) => void>();\n\n constructor() {\n this.initial = { search: \"\", sort: [], filters: {}, limit: 50 } as unknown as TParams;\n this.params = this.clone(this.initial) as unknown as TParams;\n\n makeAutoObservable(\n this,\n {\n subscribe: false,\n dispose: false\n },\n { autoBind: true }\n );\n }\n\n get(): TParams {\n return this.clone(this.params);\n }\n\n async set(updater: (params: TParams) => void): Promise<void> {\n runInAction(() => {\n updater(this.params);\n });\n this.notify();\n }\n\n async replace(next: TParams): Promise<void> {\n runInAction(() => {\n this.params = this.clone(next);\n });\n this.notify();\n }\n\n reset(): void {\n runInAction(() => {\n this.params = this.clone(this.initial);\n });\n this.notify();\n }\n\n subscribe(listener: (next: TParams) => void): () => void {\n this.listeners.add(listener);\n return () => {\n this.listeners.delete(listener);\n };\n }\n\n dispose(): void {\n this.listeners.clear();\n }\n\n private notify(): void {\n const snap = this.clone(this.params);\n for (const listener of this.listeners) {\n try {\n listener(snap);\n } catch (error) {\n // Swallow listener errors to prevent cascading failures\n console.error(\"Error in ListQueryParams listener:\", error);\n }\n }\n }\n\n private clone(value: TParams): TParams {\n return structuredClone ? structuredClone(value) : JSON.parse(JSON.stringify(value));\n }\n}\n\nexport const ListQueryParamsRepository = Abstraction.createImplementation({\n implementation: ListQueryParamsRepositoryImpl,\n dependencies: []\n});\n"],"mappings":"AAAA,SAASA,kBAAkB,EAAEC,WAAW,QAAQ,MAAM;AACtD,SACIC,yBAAyB,IAAIC,WAAW;AAK5C,OAAO,MAAMC,6BAA6B,CAE1C;EAGqBC,SAAS,GAAG,IAAIC,GAAG,CAA0B,CAAC;EAE/DC,WAAWA,CAAA,EAAG;IACV,IAAI,CAACC,OAAO,GAAG;MAAEC,MAAM,EAAE,EAAE;MAAEC,IAAI,EAAE,EAAE;MAAEC,OAAO,EAAE,CAAC,CAAC;MAAEC,KAAK,EAAE;IAAG,CAAuB;IACrF,IAAI,CAACC,MAAM,GAAG,IAAI,CAACC,KAAK,CAAC,IAAI,CAACN,OAAO,CAAuB;IAE5DR,kBAAkB,CACd,IAAI,EACJ;MACIe,SAAS,EAAE,KAAK;MAChBC,OAAO,EAAE;IACb,CAAC,EACD;MAAEC,QAAQ,EAAE;IAAK,CACrB,CAAC;EACL;EAEAC,GAAGA,CAAA,EAAY;IACX,OAAO,IAAI,CAACJ,KAAK,CAAC,IAAI,CAACD,MAAM,CAAC;EAClC;EAEA,MAAMM,GAAGA,CAACC,OAAkC,EAAiB;IACzDnB,WAAW,CAAC,MAAM;MACdmB,OAAO,CAAC,IAAI,CAACP,MAAM,CAAC;IACxB,CAAC,CAAC;IACF,IAAI,CAACQ,MAAM,CAAC,CAAC;EACjB;EAEA,MAAMC,OAAOA,CAACC,IAAa,EAAiB;IACxCtB,WAAW,CAAC,MAAM;MACd,IAAI,CAACY,MAAM,GAAG,IAAI,CAACC,KAAK,CAACS,IAAI,CAAC;IAClC,CAAC,CAAC;IACF,IAAI,CAACF,MAAM,CAAC,CAAC;EACjB;EAEAG,KAAKA,CAAA,EAAS;IACVvB,WAAW,CAAC,MAAM;MACd,IAAI,CAACY,MAAM,GAAG,IAAI,CAACC,KAAK,CAAC,IAAI,CAACN,OAAO,CAAC;IAC1C,CAAC,CAAC;IACF,IAAI,CAACa,MAAM,CAAC,CAAC;EACjB;EAEAN,SAASA,CAACU,QAAiC,EAAc;IACrD,IAAI,CAACpB,SAAS,CAACqB,GAAG,CAACD,QAAQ,CAAC;IAC5B,OAAO,MAAM;MACT,IAAI,CAACpB,SAAS,CAACsB,MAAM,CAACF,QAAQ,CAAC;IACnC,CAAC;EACL;EAEAT,OAAOA,CAAA,EAAS;IACZ,IAAI,CAACX,SAAS,CAACuB,KAAK,CAAC,CAAC;EAC1B;EAEQP,MAAMA,CAAA,EAAS;IACnB,MAAMQ,IAAI,GAAG,IAAI,CAACf,KAAK,CAAC,IAAI,CAACD,MAAM,CAAC;IACpC,KAAK,MAAMY,QAAQ,IAAI,IAAI,CAACpB,SAAS,EAAE;MACnC,IAAI;QACAoB,QAAQ,CAACI,IAAI,CAAC;MAClB,CAAC,CAAC,OAAOC,KAAK,EAAE;QACZ;QACAC,OAAO,CAACD,KAAK,CAAC,oCAAoC,EAAEA,KAAK,CAAC;MAC9D;IACJ;EACJ;EAEQhB,KAAKA,CAACkB,KAAc,EAAW;IACnC,OAAOC,eAAe,GAAGA,eAAe,CAACD,KAAK,CAAC,GAAGE,IAAI,CAACC,KAAK,CAACD,IAAI,CAACE,SAAS,CAACJ,KAAK,CAAC,CAAC;EACvF;AACJ;AAEA,OAAO,MAAM9B,yBAAyB,GAAGC,WAAW,CAACkC,oBAAoB,CAAC;EACtEC,cAAc,EAAElC,6BAA6B;EAC7CmC,YAAY,EAAE;AAClB,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { type ILoadMoreFeature, ListDataRepository, ListQueryParamsRepository, LoadingRepository, type BaseListParams } from "./abstractions.js";
|
|
2
|
+
declare class LoadMoreFeatureImpl<TItem, TParams extends BaseListParams> implements ILoadMoreFeature {
|
|
3
|
+
private repository;
|
|
4
|
+
private queryParams;
|
|
5
|
+
private loading;
|
|
6
|
+
constructor(repository: ListDataRepository.Interface<TItem, TParams>, queryParams: ListQueryParamsRepository.Interface<TParams>, loading: LoadingRepository.Interface);
|
|
7
|
+
execute(): Promise<void>;
|
|
8
|
+
private canLoadMore;
|
|
9
|
+
}
|
|
10
|
+
export declare const LoadMoreFeature: typeof LoadMoreFeatureImpl & {
|
|
11
|
+
__abstraction: import("@webiny/di").Abstraction<ILoadMoreFeature>;
|
|
12
|
+
};
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { LoadMoreFeature as Abstraction, ListDataRepository, ListQueryParamsRepository, LoadingRepository } from "./abstractions.js";
|
|
2
|
+
class LoadMoreFeatureImpl {
|
|
3
|
+
constructor(repository, queryParams, loading) {
|
|
4
|
+
this.repository = repository;
|
|
5
|
+
this.queryParams = queryParams;
|
|
6
|
+
this.loading = loading;
|
|
7
|
+
}
|
|
8
|
+
async execute() {
|
|
9
|
+
if (!this.canLoadMore()) {
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
const params = this.queryParams.get();
|
|
13
|
+
await this.loading.runCallback(this.repository.append(params), "loadMore");
|
|
14
|
+
}
|
|
15
|
+
canLoadMore() {
|
|
16
|
+
// Don't allow load more if already loading
|
|
17
|
+
if (this.loading.isLoading("loadMore")) {
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
// Check if repository has more items
|
|
22
|
+
return this.repository.hasMore();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
export const LoadMoreFeature = Abstraction.createImplementation({
|
|
26
|
+
implementation: LoadMoreFeatureImpl,
|
|
27
|
+
dependencies: [ListDataRepository, ListQueryParamsRepository, LoadingRepository]
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
//# sourceMappingURL=LoadMoreFeature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["LoadMoreFeature","Abstraction","ListDataRepository","ListQueryParamsRepository","LoadingRepository","LoadMoreFeatureImpl","constructor","repository","queryParams","loading","execute","canLoadMore","params","get","runCallback","append","isLoading","hasMore","createImplementation","implementation","dependencies"],"sources":["LoadMoreFeature.ts"],"sourcesContent":["import {\n LoadMoreFeature as Abstraction,\n type ILoadMoreFeature,\n ListDataRepository,\n ListQueryParamsRepository,\n LoadingRepository,\n type BaseListParams\n} from \"./abstractions.js\";\n\nclass LoadMoreFeatureImpl<TItem, TParams extends BaseListParams> implements ILoadMoreFeature {\n constructor(\n private repository: ListDataRepository.Interface<TItem, TParams>,\n private queryParams: ListQueryParamsRepository.Interface<TParams>,\n private loading: LoadingRepository.Interface\n ) {}\n\n async execute(): Promise<void> {\n if (!this.canLoadMore()) {\n return;\n }\n\n const params = this.queryParams.get();\n\n await this.loading.runCallback(this.repository.append(params), \"loadMore\");\n }\n\n private canLoadMore(): boolean {\n // Don't allow load more if already loading\n if (this.loading.isLoading(\"loadMore\")) {\n return false;\n }\n\n // Check if repository has more items\n return this.repository.hasMore();\n }\n}\n\nexport const LoadMoreFeature = Abstraction.createImplementation({\n implementation: LoadMoreFeatureImpl,\n dependencies: [ListDataRepository, ListQueryParamsRepository, LoadingRepository]\n});\n"],"mappings":"AAAA,SACIA,eAAe,IAAIC,WAAW,EAE9BC,kBAAkB,EAClBC,yBAAyB,EACzBC,iBAAiB;AAIrB,MAAMC,mBAAmB,CAAoE;EACzFC,WAAWA,CACCC,UAAwD,EACxDC,WAAyD,EACzDC,OAAoC,EAC9C;IAAA,KAHUF,UAAwD,GAAxDA,UAAwD;IAAA,KACxDC,WAAyD,GAAzDA,WAAyD;IAAA,KACzDC,OAAoC,GAApCA,OAAoC;EAC7C;EAEH,MAAMC,OAAOA,CAAA,EAAkB;IAC3B,IAAI,CAAC,IAAI,CAACC,WAAW,CAAC,CAAC,EAAE;MACrB;IACJ;IAEA,MAAMC,MAAM,GAAG,IAAI,CAACJ,WAAW,CAACK,GAAG,CAAC,CAAC;IAErC,MAAM,IAAI,CAACJ,OAAO,CAACK,WAAW,CAAC,IAAI,CAACP,UAAU,CAACQ,MAAM,CAACH,MAAM,CAAC,EAAE,UAAU,CAAC;EAC9E;EAEQD,WAAWA,CAAA,EAAY;IAC3B;IACA,IAAI,IAAI,CAACF,OAAO,CAACO,SAAS,CAAC,UAAU,CAAC,EAAE;MACpC,OAAO,KAAK;IAChB;;IAEA;IACA,OAAO,IAAI,CAACT,UAAU,CAACU,OAAO,CAAC,CAAC;EACpC;AACJ;AAEA,OAAO,MAAMjB,eAAe,GAAGC,WAAW,CAACiB,oBAAoB,CAAC;EAC5DC,cAAc,EAAEd,mBAAmB;EACnCe,YAAY,EAAE,CAAClB,kBAAkB,EAAEC,yBAAyB,EAAEC,iBAAiB;AACnF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type ILoadingRepository } from "./abstractions.js";
|
|
2
|
+
declare class LoadingRepositoryImpl implements ILoadingRepository {
|
|
3
|
+
private loadingStates;
|
|
4
|
+
constructor();
|
|
5
|
+
get(): Record<string, boolean>;
|
|
6
|
+
set(action: string, isLoading?: boolean): Promise<void>;
|
|
7
|
+
runCallback<T>(callback: Promise<T>, action: string): Promise<T>;
|
|
8
|
+
isLoading(action: string): boolean;
|
|
9
|
+
hasLoading(): boolean;
|
|
10
|
+
isEmpty(): boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare const LoadingRepository: typeof LoadingRepositoryImpl & {
|
|
13
|
+
__abstraction: import("@webiny/di").Abstraction<ILoadingRepository>;
|
|
14
|
+
};
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { makeAutoObservable, runInAction } from "mobx";
|
|
2
|
+
import { LoadingRepository as Abstraction } from "./abstractions.js";
|
|
3
|
+
class LoadingRepositoryImpl {
|
|
4
|
+
loadingStates = {};
|
|
5
|
+
constructor() {
|
|
6
|
+
makeAutoObservable(this, {}, {
|
|
7
|
+
autoBind: true
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
get() {
|
|
11
|
+
return {
|
|
12
|
+
...this.loadingStates
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
async set(action, isLoading = true) {
|
|
16
|
+
runInAction(() => {
|
|
17
|
+
if (isLoading) {
|
|
18
|
+
this.loadingStates[action] = true;
|
|
19
|
+
} else {
|
|
20
|
+
delete this.loadingStates[action];
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
async runCallback(callback, action) {
|
|
25
|
+
await this.set(action, true);
|
|
26
|
+
try {
|
|
27
|
+
const result = await callback;
|
|
28
|
+
await this.set(action, false);
|
|
29
|
+
return result;
|
|
30
|
+
} catch (error) {
|
|
31
|
+
await this.set(action, false);
|
|
32
|
+
throw error;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
isLoading(action) {
|
|
36
|
+
return this.loadingStates[action] === true;
|
|
37
|
+
}
|
|
38
|
+
hasLoading() {
|
|
39
|
+
return Object.keys(this.loadingStates).length > 0;
|
|
40
|
+
}
|
|
41
|
+
isEmpty() {
|
|
42
|
+
return Object.keys(this.loadingStates).length === 0;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
export const LoadingRepository = Abstraction.createImplementation({
|
|
46
|
+
implementation: LoadingRepositoryImpl,
|
|
47
|
+
dependencies: []
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
//# sourceMappingURL=LoadingRepository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["makeAutoObservable","runInAction","LoadingRepository","Abstraction","LoadingRepositoryImpl","loadingStates","constructor","autoBind","get","set","action","isLoading","runCallback","callback","result","error","hasLoading","Object","keys","length","isEmpty","createImplementation","implementation","dependencies"],"sources":["LoadingRepository.ts"],"sourcesContent":["import { makeAutoObservable, runInAction } from \"mobx\";\nimport { LoadingRepository as Abstraction, type ILoadingRepository } from \"./abstractions.js\";\n\nclass LoadingRepositoryImpl implements ILoadingRepository {\n private loadingStates: Record<string, boolean> = {};\n\n constructor() {\n makeAutoObservable(this, {}, { autoBind: true });\n }\n\n get(): Record<string, boolean> {\n return { ...this.loadingStates };\n }\n\n async set(action: string, isLoading: boolean = true): Promise<void> {\n runInAction(() => {\n if (isLoading) {\n this.loadingStates[action] = true;\n } else {\n delete this.loadingStates[action];\n }\n });\n }\n\n async runCallback<T>(callback: Promise<T>, action: string): Promise<T> {\n await this.set(action, true);\n try {\n const result = await callback;\n await this.set(action, false);\n return result;\n } catch (error) {\n await this.set(action, false);\n throw error;\n }\n }\n\n isLoading(action: string): boolean {\n return this.loadingStates[action] === true;\n }\n\n hasLoading(): boolean {\n return Object.keys(this.loadingStates).length > 0;\n }\n\n isEmpty(): boolean {\n return Object.keys(this.loadingStates).length === 0;\n }\n}\n\nexport const LoadingRepository = Abstraction.createImplementation({\n implementation: LoadingRepositoryImpl,\n dependencies: []\n});\n"],"mappings":"AAAA,SAASA,kBAAkB,EAAEC,WAAW,QAAQ,MAAM;AACtD,SAASC,iBAAiB,IAAIC,WAAW;AAEzC,MAAMC,qBAAqB,CAA+B;EAC9CC,aAAa,GAA4B,CAAC,CAAC;EAEnDC,WAAWA,CAAA,EAAG;IACVN,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE;MAAEO,QAAQ,EAAE;IAAK,CAAC,CAAC;EACpD;EAEAC,GAAGA,CAAA,EAA4B;IAC3B,OAAO;MAAE,GAAG,IAAI,CAACH;IAAc,CAAC;EACpC;EAEA,MAAMI,GAAGA,CAACC,MAAc,EAAEC,SAAkB,GAAG,IAAI,EAAiB;IAChEV,WAAW,CAAC,MAAM;MACd,IAAIU,SAAS,EAAE;QACX,IAAI,CAACN,aAAa,CAACK,MAAM,CAAC,GAAG,IAAI;MACrC,CAAC,MAAM;QACH,OAAO,IAAI,CAACL,aAAa,CAACK,MAAM,CAAC;MACrC;IACJ,CAAC,CAAC;EACN;EAEA,MAAME,WAAWA,CAAIC,QAAoB,EAAEH,MAAc,EAAc;IACnE,MAAM,IAAI,CAACD,GAAG,CAACC,MAAM,EAAE,IAAI,CAAC;IAC5B,IAAI;MACA,MAAMI,MAAM,GAAG,MAAMD,QAAQ;MAC7B,MAAM,IAAI,CAACJ,GAAG,CAACC,MAAM,EAAE,KAAK,CAAC;MAC7B,OAAOI,MAAM;IACjB,CAAC,CAAC,OAAOC,KAAK,EAAE;MACZ,MAAM,IAAI,CAACN,GAAG,CAACC,MAAM,EAAE,KAAK,CAAC;MAC7B,MAAMK,KAAK;IACf;EACJ;EAEAJ,SAASA,CAACD,MAAc,EAAW;IAC/B,OAAO,IAAI,CAACL,aAAa,CAACK,MAAM,CAAC,KAAK,IAAI;EAC9C;EAEAM,UAAUA,CAAA,EAAY;IAClB,OAAOC,MAAM,CAACC,IAAI,CAAC,IAAI,CAACb,aAAa,CAAC,CAACc,MAAM,GAAG,CAAC;EACrD;EAEAC,OAAOA,CAAA,EAAY;IACf,OAAOH,MAAM,CAACC,IAAI,CAAC,IAAI,CAACb,aAAa,CAAC,CAACc,MAAM,KAAK,CAAC;EACvD;AACJ;AAEA,OAAO,MAAMjB,iBAAiB,GAAGC,WAAW,CAACkB,oBAAoB,CAAC;EAC9DC,cAAc,EAAElB,qBAAqB;EACrCmB,YAAY,EAAE;AAClB,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type ISearchFeature, ListQueryParamsRepository, type BaseListParams } from "./abstractions.js";
|
|
2
|
+
declare class SearchFeatureImpl<TParams extends BaseListParams> implements ISearchFeature {
|
|
3
|
+
private queryParams;
|
|
4
|
+
constructor(queryParams: ListQueryParamsRepository.Interface<TParams>);
|
|
5
|
+
setSearch(query: string): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
export declare const SearchFeature: typeof SearchFeatureImpl & {
|
|
8
|
+
__abstraction: import("@webiny/di").Abstraction<ISearchFeature>;
|
|
9
|
+
};
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SearchFeature as Abstraction, ListQueryParamsRepository } from "./abstractions.js";
|
|
2
|
+
class SearchFeatureImpl {
|
|
3
|
+
constructor(queryParams) {
|
|
4
|
+
this.queryParams = queryParams;
|
|
5
|
+
}
|
|
6
|
+
async setSearch(query) {
|
|
7
|
+
await this.queryParams.set(params => {
|
|
8
|
+
params.search = query;
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export const SearchFeature = Abstraction.createImplementation({
|
|
13
|
+
implementation: SearchFeatureImpl,
|
|
14
|
+
dependencies: [ListQueryParamsRepository]
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
//# sourceMappingURL=SearchFeature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["SearchFeature","Abstraction","ListQueryParamsRepository","SearchFeatureImpl","constructor","queryParams","setSearch","query","set","params","search","createImplementation","implementation","dependencies"],"sources":["SearchFeature.ts"],"sourcesContent":["import {\n SearchFeature as Abstraction,\n type ISearchFeature,\n ListQueryParamsRepository,\n type BaseListParams\n} from \"./abstractions.js\";\n\nclass SearchFeatureImpl<TParams extends BaseListParams> implements ISearchFeature {\n constructor(private queryParams: ListQueryParamsRepository.Interface<TParams>) {}\n\n async setSearch(query: string): Promise<void> {\n await this.queryParams.set(params => {\n params.search = query;\n });\n }\n}\n\nexport const SearchFeature = Abstraction.createImplementation({\n implementation: SearchFeatureImpl,\n dependencies: [ListQueryParamsRepository]\n});\n"],"mappings":"AAAA,SACIA,aAAa,IAAIC,WAAW,EAE5BC,yBAAyB;AAI7B,MAAMC,iBAAiB,CAA2D;EAC9EC,WAAWA,CAASC,WAAyD,EAAE;IAAA,KAA3DA,WAAyD,GAAzDA,WAAyD;EAAG;EAEhF,MAAMC,SAASA,CAACC,KAAa,EAAiB;IAC1C,MAAM,IAAI,CAACF,WAAW,CAACG,GAAG,CAACC,MAAM,IAAI;MACjCA,MAAM,CAACC,MAAM,GAAGH,KAAK;IACzB,CAAC,CAAC;EACN;AACJ;AAEA,OAAO,MAAMP,aAAa,GAAGC,WAAW,CAACU,oBAAoB,CAAC;EAC1DC,cAAc,EAAET,iBAAiB;EACjCU,YAAY,EAAE,CAACX,yBAAyB;AAC5C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type ISortFeature, ListQueryParamsRepository, type BaseListParams } from "./abstractions.js";
|
|
2
|
+
declare class SortFeatureImpl<TParams extends BaseListParams> implements ISortFeature {
|
|
3
|
+
private queryParams;
|
|
4
|
+
constructor(queryParams: ListQueryParamsRepository.Interface<TParams>);
|
|
5
|
+
setSort(by: string, dir: "asc" | "desc"): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
export declare const SortFeature: typeof SortFeatureImpl & {
|
|
8
|
+
__abstraction: import("@webiny/di").Abstraction<ISortFeature>;
|
|
9
|
+
};
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { SortFeature as Abstraction, ListQueryParamsRepository } from "./abstractions.js";
|
|
2
|
+
class SortFeatureImpl {
|
|
3
|
+
constructor(queryParams) {
|
|
4
|
+
this.queryParams = queryParams;
|
|
5
|
+
}
|
|
6
|
+
async setSort(by, dir) {
|
|
7
|
+
await this.queryParams.set(params => {
|
|
8
|
+
params.sort = {
|
|
9
|
+
by,
|
|
10
|
+
dir
|
|
11
|
+
};
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
export const SortFeature = Abstraction.createImplementation({
|
|
16
|
+
implementation: SortFeatureImpl,
|
|
17
|
+
dependencies: [ListQueryParamsRepository]
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
//# sourceMappingURL=SortFeature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["SortFeature","Abstraction","ListQueryParamsRepository","SortFeatureImpl","constructor","queryParams","setSort","by","dir","set","params","sort","createImplementation","implementation","dependencies"],"sources":["SortFeature.ts"],"sourcesContent":["import {\n SortFeature as Abstraction,\n type ISortFeature,\n ListQueryParamsRepository,\n type BaseListParams\n} from \"./abstractions.js\";\n\nclass SortFeatureImpl<TParams extends BaseListParams> implements ISortFeature {\n constructor(private queryParams: ListQueryParamsRepository.Interface<TParams>) {}\n\n async setSort(by: string, dir: \"asc\" | \"desc\"): Promise<void> {\n await this.queryParams.set(params => {\n params.sort = { by, dir };\n });\n }\n}\n\nexport const SortFeature = Abstraction.createImplementation({\n implementation: SortFeatureImpl,\n dependencies: [ListQueryParamsRepository]\n});\n"],"mappings":"AAAA,SACIA,WAAW,IAAIC,WAAW,EAE1BC,yBAAyB;AAI7B,MAAMC,eAAe,CAAyD;EAC1EC,WAAWA,CAASC,WAAyD,EAAE;IAAA,KAA3DA,WAAyD,GAAzDA,WAAyD;EAAG;EAEhF,MAAMC,OAAOA,CAACC,EAAU,EAAEC,GAAmB,EAAiB;IAC1D,MAAM,IAAI,CAACH,WAAW,CAACI,GAAG,CAACC,MAAM,IAAI;MACjCA,MAAM,CAACC,IAAI,GAAG;QAAEJ,EAAE;QAAEC;MAAI,CAAC;IAC7B,CAAC,CAAC;EACN;AACJ;AAEA,OAAO,MAAMR,WAAW,GAAGC,WAAW,CAACW,oBAAoB,CAAC;EACxDC,cAAc,EAAEV,eAAe;EAC/BW,YAAY,EAAE,CAACZ,yBAAyB;AAC5C,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
export interface BaseListParams {
|
|
2
|
+
search?: string;
|
|
3
|
+
sort?: {
|
|
4
|
+
by: string;
|
|
5
|
+
dir: "asc" | "desc";
|
|
6
|
+
};
|
|
7
|
+
filters?: Record<string, unknown>;
|
|
8
|
+
limit?: number;
|
|
9
|
+
}
|
|
10
|
+
export interface IListQueryParamsRepository<TParams extends BaseListParams> {
|
|
11
|
+
get(): TParams;
|
|
12
|
+
set(updater: (params: TParams) => void): Promise<void>;
|
|
13
|
+
replace(next: TParams): Promise<void>;
|
|
14
|
+
reset(): void;
|
|
15
|
+
subscribe(listener: (next: TParams) => void): () => void;
|
|
16
|
+
dispose(): void;
|
|
17
|
+
}
|
|
18
|
+
export declare const ListQueryParamsRepository: import("@webiny/di").Abstraction<IListQueryParamsRepository<any>>;
|
|
19
|
+
export declare namespace ListQueryParamsRepository {
|
|
20
|
+
type Interface<TParams extends BaseListParams = BaseListParams> = IListQueryParamsRepository<TParams>;
|
|
21
|
+
}
|
|
22
|
+
export interface ILoadingRepository {
|
|
23
|
+
get(): Record<string, boolean>;
|
|
24
|
+
set(action: string, isLoading?: boolean): Promise<void>;
|
|
25
|
+
runCallback<T>(callback: Promise<T>, action: string): Promise<T>;
|
|
26
|
+
isLoading(action: string): boolean;
|
|
27
|
+
hasLoading(): boolean;
|
|
28
|
+
isEmpty(): boolean;
|
|
29
|
+
}
|
|
30
|
+
export declare const LoadingRepository: import("@webiny/di").Abstraction<ILoadingRepository>;
|
|
31
|
+
export declare namespace LoadingRepository {
|
|
32
|
+
type Interface = ILoadingRepository;
|
|
33
|
+
}
|
|
34
|
+
export interface IListDataRepository<TItem, TParams extends BaseListParams> {
|
|
35
|
+
load(params: TParams): Promise<void>;
|
|
36
|
+
append(params: TParams): Promise<void>;
|
|
37
|
+
getAll(): TItem[];
|
|
38
|
+
hasMore(): boolean;
|
|
39
|
+
clear(): void;
|
|
40
|
+
}
|
|
41
|
+
export declare const ListDataRepository: import("@webiny/di").Abstraction<IListDataRepository<any, any>>;
|
|
42
|
+
export declare namespace ListDataRepository {
|
|
43
|
+
type Interface<TItem = any, TParams extends BaseListParams = BaseListParams> = IListDataRepository<TItem, TParams>;
|
|
44
|
+
}
|
|
45
|
+
export interface ISearchFeature {
|
|
46
|
+
setSearch(query: string): Promise<void>;
|
|
47
|
+
}
|
|
48
|
+
export declare const SearchFeature: import("@webiny/di").Abstraction<ISearchFeature>;
|
|
49
|
+
export declare namespace SearchFeature {
|
|
50
|
+
type Interface = ISearchFeature;
|
|
51
|
+
}
|
|
52
|
+
export interface IFilterFeature {
|
|
53
|
+
setFilter(key: string, value: unknown): Promise<void>;
|
|
54
|
+
clearAllFilters(): Promise<void>;
|
|
55
|
+
}
|
|
56
|
+
export declare const FilterFeature: import("@webiny/di").Abstraction<IFilterFeature>;
|
|
57
|
+
export declare namespace FilterFeature {
|
|
58
|
+
type Interface = IFilterFeature;
|
|
59
|
+
}
|
|
60
|
+
export interface ISortFeature {
|
|
61
|
+
setSort(by: string, dir: "asc" | "desc"): Promise<void>;
|
|
62
|
+
}
|
|
63
|
+
export declare const SortFeature: import("@webiny/di").Abstraction<ISortFeature>;
|
|
64
|
+
export declare namespace SortFeature {
|
|
65
|
+
type Interface = ISortFeature;
|
|
66
|
+
}
|
|
67
|
+
export interface ILoadMoreFeature {
|
|
68
|
+
execute(): Promise<void>;
|
|
69
|
+
}
|
|
70
|
+
export declare const LoadMoreFeature: import("@webiny/di").Abstraction<ILoadMoreFeature>;
|
|
71
|
+
export declare namespace LoadMoreFeature {
|
|
72
|
+
type Interface = ILoadMoreFeature;
|
|
73
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { createAbstraction } from "@webiny/feature/admin";
|
|
2
|
+
|
|
3
|
+
// ============================================================================
|
|
4
|
+
// Base Types
|
|
5
|
+
// ============================================================================
|
|
6
|
+
|
|
7
|
+
// ============================================================================
|
|
8
|
+
// Query Params Repository
|
|
9
|
+
// ============================================================================
|
|
10
|
+
|
|
11
|
+
export const ListQueryParamsRepository = createAbstraction("ListQueryParamsRepository");
|
|
12
|
+
|
|
13
|
+
// ============================================================================
|
|
14
|
+
// Loading Repository
|
|
15
|
+
// ============================================================================
|
|
16
|
+
|
|
17
|
+
export const LoadingRepository = createAbstraction("LoadingRepository");
|
|
18
|
+
|
|
19
|
+
// ============================================================================
|
|
20
|
+
// List Data Repository
|
|
21
|
+
// ============================================================================
|
|
22
|
+
|
|
23
|
+
export const ListDataRepository = createAbstraction("ListDataRepository");
|
|
24
|
+
|
|
25
|
+
// ============================================================================
|
|
26
|
+
// Features
|
|
27
|
+
// ============================================================================
|
|
28
|
+
|
|
29
|
+
export const SearchFeature = createAbstraction("SearchFeature");
|
|
30
|
+
export const FilterFeature = createAbstraction("FilterFeature");
|
|
31
|
+
export const SortFeature = createAbstraction("SortFeature");
|
|
32
|
+
export const LoadMoreFeature = createAbstraction("LoadMoreFeature");
|
|
33
|
+
|
|
34
|
+
//# sourceMappingURL=abstractions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createAbstraction","ListQueryParamsRepository","LoadingRepository","ListDataRepository","SearchFeature","FilterFeature","SortFeature","LoadMoreFeature"],"sources":["abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/admin\";\n\n// ============================================================================\n// Base Types\n// ============================================================================\n\nexport interface BaseListParams {\n search?: string;\n sort?: { by: string; dir: \"asc\" | \"desc\" };\n filters?: Record<string, unknown>;\n limit?: number;\n}\n\n// ============================================================================\n// Query Params Repository\n// ============================================================================\n\nexport interface IListQueryParamsRepository<TParams extends BaseListParams> {\n get(): TParams;\n set(updater: (params: TParams) => void): Promise<void>;\n replace(next: TParams): Promise<void>;\n reset(): void;\n subscribe(listener: (next: TParams) => void): () => void;\n dispose(): void;\n}\n\nexport const ListQueryParamsRepository = createAbstraction<IListQueryParamsRepository<any>>(\n \"ListQueryParamsRepository\"\n);\n\nexport namespace ListQueryParamsRepository {\n export type Interface<TParams extends BaseListParams = BaseListParams> =\n IListQueryParamsRepository<TParams>;\n}\n\n// ============================================================================\n// Loading Repository\n// ============================================================================\n\nexport interface ILoadingRepository {\n get(): Record<string, boolean>;\n set(action: string, isLoading?: boolean): Promise<void>;\n runCallback<T>(callback: Promise<T>, action: string): Promise<T>;\n isLoading(action: string): boolean;\n hasLoading(): boolean;\n isEmpty(): boolean;\n}\n\nexport const LoadingRepository = createAbstraction<ILoadingRepository>(\"LoadingRepository\");\n\nexport namespace LoadingRepository {\n export type Interface = ILoadingRepository;\n}\n\n// ============================================================================\n// List Data Repository\n// ============================================================================\n\nexport interface IListDataRepository<TItem, TParams extends BaseListParams> {\n load(params: TParams): Promise<void>;\n append(params: TParams): Promise<void>;\n getAll(): TItem[];\n hasMore(): boolean;\n clear(): void;\n}\n\nexport const ListDataRepository =\n createAbstraction<IListDataRepository<any, any>>(\"ListDataRepository\");\n\nexport namespace ListDataRepository {\n export type Interface<\n TItem = any,\n TParams extends BaseListParams = BaseListParams\n > = IListDataRepository<TItem, TParams>;\n}\n\n// ============================================================================\n// Features\n// ============================================================================\n\nexport interface ISearchFeature {\n setSearch(query: string): Promise<void>;\n}\n\nexport const SearchFeature = createAbstraction<ISearchFeature>(\"SearchFeature\");\n\nexport namespace SearchFeature {\n export type Interface = ISearchFeature;\n}\n\nexport interface IFilterFeature {\n setFilter(key: string, value: unknown): Promise<void>;\n clearAllFilters(): Promise<void>;\n}\n\nexport const FilterFeature = createAbstraction<IFilterFeature>(\"FilterFeature\");\n\nexport namespace FilterFeature {\n export type Interface = IFilterFeature;\n}\n\nexport interface ISortFeature {\n setSort(by: string, dir: \"asc\" | \"desc\"): Promise<void>;\n}\n\nexport const SortFeature = createAbstraction<ISortFeature>(\"SortFeature\");\n\nexport namespace SortFeature {\n export type Interface = ISortFeature;\n}\n\nexport interface ILoadMoreFeature {\n execute(): Promise<void>;\n}\n\nexport const LoadMoreFeature = createAbstraction<ILoadMoreFeature>(\"LoadMoreFeature\");\n\nexport namespace LoadMoreFeature {\n export type Interface = ILoadMoreFeature;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,uBAAuB;;AAEzD;AACA;AACA;;AASA;AACA;AACA;;AAWA,OAAO,MAAMC,yBAAyB,GAAGD,iBAAiB,CACtD,2BACJ,CAAC;;AAOD;AACA;AACA;;AAWA,OAAO,MAAME,iBAAiB,GAAGF,iBAAiB,CAAqB,mBAAmB,CAAC;;AAM3F;AACA;AACA;;AAUA,OAAO,MAAMG,kBAAkB,GAC3BH,iBAAiB,CAAgC,oBAAoB,CAAC;;AAS1E;AACA;AACA;;AAMA,OAAO,MAAMI,aAAa,GAAGJ,iBAAiB,CAAiB,eAAe,CAAC;AAW/E,OAAO,MAAMK,aAAa,GAAGL,iBAAiB,CAAiB,eAAe,CAAC;AAU/E,OAAO,MAAMM,WAAW,GAAGN,iBAAiB,CAAe,aAAa,CAAC;AAUzE,OAAO,MAAMO,eAAe,GAAGP,iBAAiB,CAAmB,iBAAiB,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare const ListFeature: import("@webiny/feature/admin/createFeature.js").FeatureDefinition<{
|
|
2
|
+
queryParams: import("./abstractions.js").IListQueryParamsRepository<any>;
|
|
3
|
+
loading: import("./abstractions.js").ILoadingRepository;
|
|
4
|
+
search: import("./abstractions.js").ISearchFeature;
|
|
5
|
+
filter: import("./abstractions.js").IFilterFeature;
|
|
6
|
+
sort: import("./abstractions.js").ISortFeature;
|
|
7
|
+
loadMore: import("./abstractions.js").ILoadMoreFeature;
|
|
8
|
+
}, []>;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { createFeature } from "@webiny/feature/admin/index.js";
|
|
2
|
+
import { ListQueryParamsRepository as QueryParamsAbstraction, LoadingRepository as LoadingAbstraction, SearchFeature as SearchAbstraction, FilterFeature as FilterAbstraction, SortFeature as SortAbstraction, LoadMoreFeature as LoadMoreAbstraction } from "./abstractions.js";
|
|
3
|
+
import { ListQueryParamsRepository } from "./ListQueryParamsRepository.js";
|
|
4
|
+
import { LoadingRepository } from "./LoadingRepository.js";
|
|
5
|
+
import { SearchFeature } from "./SearchFeature.js";
|
|
6
|
+
import { FilterFeature } from "./FilterFeature.js";
|
|
7
|
+
import { SortFeature } from "./SortFeature.js";
|
|
8
|
+
import { LoadMoreFeature } from "./LoadMoreFeature.js";
|
|
9
|
+
export const ListFeature = createFeature({
|
|
10
|
+
name: "ListFeature",
|
|
11
|
+
register: container => {
|
|
12
|
+
// Register infrastructure
|
|
13
|
+
container.register(ListQueryParamsRepository);
|
|
14
|
+
container.register(LoadingRepository);
|
|
15
|
+
|
|
16
|
+
// Register features
|
|
17
|
+
container.register(SearchFeature);
|
|
18
|
+
container.register(FilterFeature);
|
|
19
|
+
container.register(SortFeature);
|
|
20
|
+
container.register(LoadMoreFeature);
|
|
21
|
+
},
|
|
22
|
+
resolve: container => {
|
|
23
|
+
return {
|
|
24
|
+
queryParams: container.resolve(QueryParamsAbstraction),
|
|
25
|
+
loading: container.resolve(LoadingAbstraction),
|
|
26
|
+
search: container.resolve(SearchAbstraction),
|
|
27
|
+
filter: container.resolve(FilterAbstraction),
|
|
28
|
+
sort: container.resolve(SortAbstraction),
|
|
29
|
+
loadMore: container.resolve(LoadMoreAbstraction)
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
//# sourceMappingURL=feature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createFeature","ListQueryParamsRepository","QueryParamsAbstraction","LoadingRepository","LoadingAbstraction","SearchFeature","SearchAbstraction","FilterFeature","FilterAbstraction","SortFeature","SortAbstraction","LoadMoreFeature","LoadMoreAbstraction","ListFeature","name","register","container","resolve","queryParams","loading","search","filter","sort","loadMore"],"sources":["feature.ts"],"sourcesContent":["import { createFeature } from \"@webiny/feature/admin/index.js\";\nimport {\n ListQueryParamsRepository as QueryParamsAbstraction,\n LoadingRepository as LoadingAbstraction,\n SearchFeature as SearchAbstraction,\n FilterFeature as FilterAbstraction,\n SortFeature as SortAbstraction,\n LoadMoreFeature as LoadMoreAbstraction\n} from \"./abstractions.js\";\nimport { ListQueryParamsRepository } from \"./ListQueryParamsRepository.js\";\nimport { LoadingRepository } from \"./LoadingRepository.js\";\nimport { SearchFeature } from \"./SearchFeature.js\";\nimport { FilterFeature } from \"./FilterFeature.js\";\nimport { SortFeature } from \"./SortFeature.js\";\nimport { LoadMoreFeature } from \"./LoadMoreFeature.js\";\n\nexport const ListFeature = createFeature({\n name: \"ListFeature\",\n register: container => {\n // Register infrastructure\n container.register(ListQueryParamsRepository);\n container.register(LoadingRepository);\n\n // Register features\n container.register(SearchFeature);\n container.register(FilterFeature);\n container.register(SortFeature);\n container.register(LoadMoreFeature);\n },\n resolve: container => {\n return {\n queryParams: container.resolve(QueryParamsAbstraction),\n loading: container.resolve(LoadingAbstraction),\n search: container.resolve(SearchAbstraction),\n filter: container.resolve(FilterAbstraction),\n sort: container.resolve(SortAbstraction),\n loadMore: container.resolve(LoadMoreAbstraction)\n };\n }\n});\n"],"mappings":"AAAA,SAASA,aAAa,QAAQ,gCAAgC;AAC9D,SACIC,yBAAyB,IAAIC,sBAAsB,EACnDC,iBAAiB,IAAIC,kBAAkB,EACvCC,aAAa,IAAIC,iBAAiB,EAClCC,aAAa,IAAIC,iBAAiB,EAClCC,WAAW,IAAIC,eAAe,EAC9BC,eAAe,IAAIC,mBAAmB;AAE1C,SAASX,yBAAyB;AAClC,SAASE,iBAAiB;AAC1B,SAASE,aAAa;AACtB,SAASE,aAAa;AACtB,SAASE,WAAW;AACpB,SAASE,eAAe;AAExB,OAAO,MAAME,WAAW,GAAGb,aAAa,CAAC;EACrCc,IAAI,EAAE,aAAa;EACnBC,QAAQ,EAAEC,SAAS,IAAI;IACnB;IACAA,SAAS,CAACD,QAAQ,CAACd,yBAAyB,CAAC;IAC7Ce,SAAS,CAACD,QAAQ,CAACZ,iBAAiB,CAAC;;IAErC;IACAa,SAAS,CAACD,QAAQ,CAACV,aAAa,CAAC;IACjCW,SAAS,CAACD,QAAQ,CAACR,aAAa,CAAC;IACjCS,SAAS,CAACD,QAAQ,CAACN,WAAW,CAAC;IAC/BO,SAAS,CAACD,QAAQ,CAACJ,eAAe,CAAC;EACvC,CAAC;EACDM,OAAO,EAAED,SAAS,IAAI;IAClB,OAAO;MACHE,WAAW,EAAEF,SAAS,CAACC,OAAO,CAACf,sBAAsB,CAAC;MACtDiB,OAAO,EAAEH,SAAS,CAACC,OAAO,CAACb,kBAAkB,CAAC;MAC9CgB,MAAM,EAAEJ,SAAS,CAACC,OAAO,CAACX,iBAAiB,CAAC;MAC5Ce,MAAM,EAAEL,SAAS,CAACC,OAAO,CAACT,iBAAiB,CAAC;MAC5Cc,IAAI,EAAEN,SAAS,CAACC,OAAO,CAACP,eAAe,CAAC;MACxCa,QAAQ,EAAEP,SAAS,CAACC,OAAO,CAACL,mBAAmB;IACnD,CAAC;EACL;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["MetaMapper","toDto","data","totalCount","cursor","hasMoreItems"],"sources":["MetaMapper.ts"],"sourcesContent":["import type { Meta, MetaDTO } from \"./Meta\";\n\nexport class MetaMapper {\n static toDto(data: Meta | MetaDTO): MetaDTO {\n return {\n totalCount: data.totalCount ?? 0,\n cursor: data.cursor ?? null,\n hasMoreItems: data.hasMoreItems ?? false\n };\n }\n}\n"],"mappings":"AAEA,OAAO,MAAMA,UAAU,CAAC;EACpB,OAAOC,KAAKA,CAACC,IAAoB,EAAW;IACxC,OAAO;MACHC,UAAU,EAAED,IAAI,CAACC,UAAU,IAAI,CAAC;MAChCC,MAAM,EAAEF,IAAI,CAACE,MAAM,IAAI,IAAI;MAC3BC,YAAY,EAAEH,IAAI,CAACG,YAAY,IAAI;IACvC,CAAC;EACL;AACJ","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["MetaMapper","toDto","data","totalCount","cursor","hasMoreItems"],"sources":["MetaMapper.ts"],"sourcesContent":["import type { Meta, MetaDTO } from \"./Meta.js\";\n\nexport class MetaMapper {\n static toDto(data: Meta | MetaDTO): MetaDTO {\n return {\n totalCount: data.totalCount ?? 0,\n cursor: data.cursor ?? null,\n hasMoreItems: data.hasMoreItems ?? false\n };\n }\n}\n"],"mappings":"AAEA,OAAO,MAAMA,UAAU,CAAC;EACpB,OAAOC,KAAKA,CAACC,IAAoB,EAAW;IACxC,OAAO;MACHC,UAAU,EAAED,IAAI,CAACC,UAAU,IAAI,CAAC;MAChCC,MAAM,EAAEF,IAAI,CAACE,MAAM,IAAI,IAAI;MAC3BC,YAAY,EAAEH,IAAI,CAACG,YAAY,IAAI;IACvC,CAAC;EACL;AACJ","ignoreList":[]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from "./Meta";
|
|
2
|
-
export * from "./MetaMapper";
|
|
1
|
+
export * from "./Meta.js";
|
|
2
|
+
export * from "./MetaMapper.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Meta\";\nexport * from \"./MetaMapper\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Meta.js\";\nexport * from \"./MetaMapper.js\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["SortingMapper","toDTO","data","field","order","fromColumnToDTO","id","desc","fromDTOtoColumn","fromDTOtoDb"],"sources":["SortingMapper.ts"],"sourcesContent":["import type { Sorting, SortingDTO } from \"./Sorting\";\n\nexport type DbSorting = `${string}_ASC` | `${string}_DESC`;\n\nexport interface ColumnSorting {\n id: string;\n desc: boolean;\n}\n\nexport class SortingMapper {\n static toDTO(data: Sorting | SortingDTO): SortingDTO {\n const { field, order } = data;\n\n return {\n field,\n order\n };\n }\n\n static fromColumnToDTO(data: ColumnSorting): SortingDTO {\n const { id, desc } = data;\n\n return {\n field: id,\n order: desc ? \"desc\" : \"asc\"\n };\n }\n\n static fromDTOtoColumn(data: SortingDTO): ColumnSorting {\n const { field, order } = data;\n\n return {\n id: field,\n desc: order === \"desc\"\n };\n }\n\n static fromDTOtoDb(data: SortingDTO): DbSorting {\n const { field, order } = data;\n\n if (order === \"asc\") {\n return `${field}_ASC`;\n }\n\n return `${field}_DESC`;\n }\n}\n"],"mappings":"AASA,OAAO,MAAMA,aAAa,CAAC;EACvB,OAAOC,KAAKA,CAACC,IAA0B,EAAc;IACjD,MAAM;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAGF,IAAI;IAE7B,OAAO;MACHC,KAAK;MACLC;IACJ,CAAC;EACL;EAEA,OAAOC,eAAeA,CAACH,IAAmB,EAAc;IACpD,MAAM;MAAEI,EAAE;MAAEC;IAAK,CAAC,GAAGL,IAAI;IAEzB,OAAO;MACHC,KAAK,EAAEG,EAAE;MACTF,KAAK,EAAEG,IAAI,GAAG,MAAM,GAAG;IAC3B,CAAC;EACL;EAEA,OAAOC,eAAeA,CAACN,IAAgB,EAAiB;IACpD,MAAM;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAGF,IAAI;IAE7B,OAAO;MACHI,EAAE,EAAEH,KAAK;MACTI,IAAI,EAAEH,KAAK,KAAK;IACpB,CAAC;EACL;EAEA,OAAOK,WAAWA,CAACP,IAAgB,EAAa;IAC5C,MAAM;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAGF,IAAI;IAE7B,IAAIE,KAAK,KAAK,KAAK,EAAE;MACjB,OAAO,GAAGD,KAAK,MAAM;IACzB;IAEA,OAAO,GAAGA,KAAK,OAAO;EAC1B;AACJ","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["SortingMapper","toDTO","data","field","order","fromColumnToDTO","id","desc","fromDTOtoColumn","fromDTOtoDb"],"sources":["SortingMapper.ts"],"sourcesContent":["import type { Sorting, SortingDTO } from \"./Sorting.js\";\n\nexport type DbSorting = `${string}_ASC` | `${string}_DESC`;\n\nexport interface ColumnSorting {\n id: string;\n desc: boolean;\n}\n\nexport class SortingMapper {\n static toDTO(data: Sorting | SortingDTO): SortingDTO {\n const { field, order } = data;\n\n return {\n field,\n order\n };\n }\n\n static fromColumnToDTO(data: ColumnSorting): SortingDTO {\n const { id, desc } = data;\n\n return {\n field: id,\n order: desc ? \"desc\" : \"asc\"\n };\n }\n\n static fromDTOtoColumn(data: SortingDTO): ColumnSorting {\n const { field, order } = data;\n\n return {\n id: field,\n desc: order === \"desc\"\n };\n }\n\n static fromDTOtoDb(data: SortingDTO): DbSorting {\n const { field, order } = data;\n\n if (order === \"asc\") {\n return `${field}_ASC`;\n }\n\n return `${field}_DESC`;\n }\n}\n"],"mappings":"AASA,OAAO,MAAMA,aAAa,CAAC;EACvB,OAAOC,KAAKA,CAACC,IAA0B,EAAc;IACjD,MAAM;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAGF,IAAI;IAE7B,OAAO;MACHC,KAAK;MACLC;IACJ,CAAC;EACL;EAEA,OAAOC,eAAeA,CAACH,IAAmB,EAAc;IACpD,MAAM;MAAEI,EAAE;MAAEC;IAAK,CAAC,GAAGL,IAAI;IAEzB,OAAO;MACHC,KAAK,EAAEG,EAAE;MACTF,KAAK,EAAEG,IAAI,GAAG,MAAM,GAAG;IAC3B,CAAC;EACL;EAEA,OAAOC,eAAeA,CAACN,IAAgB,EAAiB;IACpD,MAAM;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAGF,IAAI;IAE7B,OAAO;MACHI,EAAE,EAAEH,KAAK;MACTI,IAAI,EAAEH,KAAK,KAAK;IACpB,CAAC;EACL;EAEA,OAAOK,WAAWA,CAACP,IAAgB,EAAa;IAC5C,MAAM;MAAEC,KAAK;MAAEC;IAAM,CAAC,GAAGF,IAAI;IAE7B,IAAIE,KAAK,KAAK,KAAK,EAAE;MACjB,OAAO,GAAGD,KAAK,MAAM;IACzB;IAEA,OAAO,GAAGA,KAAK,OAAO;EAC1B;AACJ","ignoreList":[]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from "./Sorting";
|
|
2
|
-
export * from "./SortingMapper";
|
|
1
|
+
export * from "./Sorting.js";
|
|
2
|
+
export * from "./SortingMapper.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Sorting\";\nexport * from \"./SortingMapper\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Sorting.js\";\nexport * from \"./SortingMapper.js\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from "./Meta";
|
|
2
|
-
export * from "./Sorting";
|
|
1
|
+
export * from "./Meta/index.js";
|
|
2
|
+
export * from "./Sorting/index.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Meta\";\nexport * from \"./Sorting\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Meta/index.js\";\nexport * from \"./Sorting/index.js\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export interface ILoadingRepository {
|
|
2
2
|
get: () => Record<string, boolean>;
|
|
3
3
|
set: (action: string, isLoading?: boolean) => Promise<void>;
|
|
4
|
+
getActiveLoadings(): string[];
|
|
4
5
|
runCallBack: <T>(callback: Promise<T>, action: string) => Promise<T>;
|
|
5
6
|
isLoading: (action: string) => boolean;
|
|
6
7
|
hasLoading: () => boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["ILoadingRepository.ts"],"sourcesContent":["export interface ILoadingRepository {\n get: () => Record<string, boolean>;\n set: (action: string, isLoading?: boolean) => Promise<void>;\n runCallBack: <T>(callback: Promise<T>, action: string) => Promise<T>;\n isLoading: (action: string) => boolean;\n hasLoading: () => boolean;\n isEmpty: () => boolean;\n}\n"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["ILoadingRepository.ts"],"sourcesContent":["export interface ILoadingRepository {\n get: () => Record<string, boolean>;\n set: (action: string, isLoading?: boolean) => Promise<void>;\n getActiveLoadings(): string[];\n runCallBack: <T>(callback: Promise<T>, action: string) => Promise<T>;\n isLoading: (action: string) => boolean;\n hasLoading: () => boolean;\n isEmpty: () => boolean;\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -24,9 +24,14 @@ export class LoadingRepository {
|
|
|
24
24
|
}
|
|
25
25
|
async runCallBack(callback, action) {
|
|
26
26
|
await this.set(action, true);
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
27
|
+
try {
|
|
28
|
+
const result = await callback;
|
|
29
|
+
await this.set(action, false);
|
|
30
|
+
return result;
|
|
31
|
+
} catch (error) {
|
|
32
|
+
await this.set(action, false);
|
|
33
|
+
throw error;
|
|
34
|
+
}
|
|
30
35
|
}
|
|
31
36
|
}
|
|
32
37
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["makeAutoObservable","LoadingRepository","constructor","loadings","Map","get","Object","fromEntries","getActiveLoadings","entries","filter","value","map","key","hasLoading","values","some","Boolean","isLoading","action","isEmpty","size","set","runCallBack","callback","result"],"sources":["LoadingRepository.ts"],"sourcesContent":["import { makeAutoObservable } from \"mobx\";\nimport type { ILoadingRepository } from \"./ILoadingRepository\";\n\nexport class LoadingRepository implements ILoadingRepository {\n private loadings: Map<string, boolean>;\n\n constructor() {\n this.loadings = new Map();\n makeAutoObservable(this);\n }\n\n get() {\n return Object.fromEntries(this.loadings);\n }\n\n getActiveLoadings(): string[] {\n return [...this.loadings.entries()].filter(([, value]) => value).map(([key]) => key);\n }\n\n hasLoading() {\n return [...this.loadings.values()].some(Boolean);\n }\n\n isLoading(action: string) {\n return this.loadings.get(action) ?? false;\n }\n\n isEmpty() {\n return this.loadings.size === 0;\n }\n\n async set(action: string, isLoading = true) {\n this.loadings.set(action, isLoading);\n }\n\n async runCallBack(callback: Promise<any>, action: string) {\n await this.set(action, true);\n const result = await callback;\n
|
|
1
|
+
{"version":3,"names":["makeAutoObservable","LoadingRepository","constructor","loadings","Map","get","Object","fromEntries","getActiveLoadings","entries","filter","value","map","key","hasLoading","values","some","Boolean","isLoading","action","isEmpty","size","set","runCallBack","callback","result","error"],"sources":["LoadingRepository.ts"],"sourcesContent":["import { makeAutoObservable } from \"mobx\";\nimport type { ILoadingRepository } from \"./ILoadingRepository.js\";\n\nexport class LoadingRepository implements ILoadingRepository {\n private loadings: Map<string, boolean>;\n\n constructor() {\n this.loadings = new Map();\n makeAutoObservable(this);\n }\n\n get() {\n return Object.fromEntries(this.loadings);\n }\n\n getActiveLoadings(): string[] {\n return [...this.loadings.entries()].filter(([, value]) => value).map(([key]) => key);\n }\n\n hasLoading() {\n return [...this.loadings.values()].some(Boolean);\n }\n\n isLoading(action: string) {\n return this.loadings.get(action) ?? false;\n }\n\n isEmpty() {\n return this.loadings.size === 0;\n }\n\n async set(action: string, isLoading = true) {\n this.loadings.set(action, isLoading);\n }\n\n async runCallBack(callback: Promise<any>, action: string) {\n await this.set(action, true);\n try {\n const result = await callback;\n await this.set(action, false);\n return result;\n } catch (error) {\n await this.set(action, false);\n throw error;\n }\n }\n}\n"],"mappings":"AAAA,SAASA,kBAAkB,QAAQ,MAAM;AAGzC,OAAO,MAAMC,iBAAiB,CAA+B;EAGzDC,WAAWA,CAAA,EAAG;IACV,IAAI,CAACC,QAAQ,GAAG,IAAIC,GAAG,CAAC,CAAC;IACzBJ,kBAAkB,CAAC,IAAI,CAAC;EAC5B;EAEAK,GAAGA,CAAA,EAAG;IACF,OAAOC,MAAM,CAACC,WAAW,CAAC,IAAI,CAACJ,QAAQ,CAAC;EAC5C;EAEAK,iBAAiBA,CAAA,EAAa;IAC1B,OAAO,CAAC,GAAG,IAAI,CAACL,QAAQ,CAACM,OAAO,CAAC,CAAC,CAAC,CAACC,MAAM,CAAC,CAAC,GAAGC,KAAK,CAAC,KAAKA,KAAK,CAAC,CAACC,GAAG,CAAC,CAAC,CAACC,GAAG,CAAC,KAAKA,GAAG,CAAC;EACxF;EAEAC,UAAUA,CAAA,EAAG;IACT,OAAO,CAAC,GAAG,IAAI,CAACX,QAAQ,CAACY,MAAM,CAAC,CAAC,CAAC,CAACC,IAAI,CAACC,OAAO,CAAC;EACpD;EAEAC,SAASA,CAACC,MAAc,EAAE;IACtB,OAAO,IAAI,CAAChB,QAAQ,CAACE,GAAG,CAACc,MAAM,CAAC,IAAI,KAAK;EAC7C;EAEAC,OAAOA,CAAA,EAAG;IACN,OAAO,IAAI,CAACjB,QAAQ,CAACkB,IAAI,KAAK,CAAC;EACnC;EAEA,MAAMC,GAAGA,CAACH,MAAc,EAAED,SAAS,GAAG,IAAI,EAAE;IACxC,IAAI,CAACf,QAAQ,CAACmB,GAAG,CAACH,MAAM,EAAED,SAAS,CAAC;EACxC;EAEA,MAAMK,WAAWA,CAACC,QAAsB,EAAEL,MAAc,EAAE;IACtD,MAAM,IAAI,CAACG,GAAG,CAACH,MAAM,EAAE,IAAI,CAAC;IAC5B,IAAI;MACA,MAAMM,MAAM,GAAG,MAAMD,QAAQ;MAC7B,MAAM,IAAI,CAACF,GAAG,CAACH,MAAM,EAAE,KAAK,CAAC;MAC7B,OAAOM,MAAM;IACjB,CAAC,CAAC,OAAOC,KAAK,EAAE;MACZ,MAAM,IAAI,CAACJ,GAAG,CAACH,MAAM,EAAE,KAAK,CAAC;MAC7B,MAAMO,KAAK;IACf;EACJ;AACJ","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["LoadingRepository","LoadingRepositoryFactory","cache","Map","getRepository","namespace","cacheKey","getCacheKey","has","set","get","Date","now","toString","loadingRepositoryFactory"],"sources":["LoadingRepositoryFactory.ts"],"sourcesContent":["import { LoadingRepository } from \"./LoadingRepository\";\n\nexport class LoadingRepositoryFactory {\n private cache: Map<string, LoadingRepository> = new Map();\n\n getRepository(namespace?: string) {\n const cacheKey = this.getCacheKey(namespace);\n\n if (!this.cache.has(cacheKey)) {\n this.cache.set(cacheKey, new LoadingRepository());\n }\n\n return this.cache.get(cacheKey) as LoadingRepository;\n }\n\n private getCacheKey(namespace?: string) {\n return namespace ?? Date.now().toString();\n }\n}\n\nexport const loadingRepositoryFactory = new LoadingRepositoryFactory();\n"],"mappings":"AAAA,SAASA,iBAAiB;AAE1B,OAAO,MAAMC,wBAAwB,CAAC;EAC1BC,KAAK,GAAmC,IAAIC,GAAG,CAAC,CAAC;EAEzDC,aAAaA,CAACC,SAAkB,EAAE;IAC9B,MAAMC,QAAQ,GAAG,IAAI,CAACC,WAAW,CAACF,SAAS,CAAC;IAE5C,IAAI,CAAC,IAAI,CAACH,KAAK,CAACM,GAAG,CAACF,QAAQ,CAAC,EAAE;MAC3B,IAAI,CAACJ,KAAK,CAACO,GAAG,CAACH,QAAQ,EAAE,IAAIN,iBAAiB,CAAC,CAAC,CAAC;IACrD;IAEA,OAAO,IAAI,CAACE,KAAK,CAACQ,GAAG,CAACJ,QAAQ,CAAC;EACnC;EAEQC,WAAWA,CAACF,SAAkB,EAAE;IACpC,OAAOA,SAAS,IAAIM,IAAI,CAACC,GAAG,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EAC7C;AACJ;AAEA,OAAO,MAAMC,wBAAwB,GAAG,IAAIb,wBAAwB,CAAC,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["LoadingRepository","LoadingRepositoryFactory","cache","Map","getRepository","namespace","cacheKey","getCacheKey","has","set","get","Date","now","toString","loadingRepositoryFactory"],"sources":["LoadingRepositoryFactory.ts"],"sourcesContent":["import { LoadingRepository } from \"./LoadingRepository.js\";\n\nexport class LoadingRepositoryFactory {\n private cache: Map<string, LoadingRepository> = new Map();\n\n getRepository(namespace?: string) {\n const cacheKey = this.getCacheKey(namespace);\n\n if (!this.cache.has(cacheKey)) {\n this.cache.set(cacheKey, new LoadingRepository());\n }\n\n return this.cache.get(cacheKey) as LoadingRepository;\n }\n\n private getCacheKey(namespace?: string) {\n return namespace ?? Date.now().toString();\n }\n}\n\nexport const loadingRepositoryFactory = new LoadingRepositoryFactory();\n"],"mappings":"AAAA,SAASA,iBAAiB;AAE1B,OAAO,MAAMC,wBAAwB,CAAC;EAC1BC,KAAK,GAAmC,IAAIC,GAAG,CAAC,CAAC;EAEzDC,aAAaA,CAACC,SAAkB,EAAE;IAC9B,MAAMC,QAAQ,GAAG,IAAI,CAACC,WAAW,CAACF,SAAS,CAAC;IAE5C,IAAI,CAAC,IAAI,CAACH,KAAK,CAACM,GAAG,CAACF,QAAQ,CAAC,EAAE;MAC3B,IAAI,CAACJ,KAAK,CAACO,GAAG,CAACH,QAAQ,EAAE,IAAIN,iBAAiB,CAAC,CAAC,CAAC;IACrD;IAEA,OAAO,IAAI,CAACE,KAAK,CAACQ,GAAG,CAACJ,QAAQ,CAAC;EACnC;EAEQC,WAAWA,CAACF,SAAkB,EAAE;IACpC,OAAOA,SAAS,IAAIM,IAAI,CAACC,GAAG,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EAC7C;AACJ;AAEA,OAAO,MAAMC,wBAAwB,GAAG,IAAIb,wBAAwB,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./ILoadingRepository";
|
|
2
|
-
export * from "./LoadingRepository";
|
|
3
|
-
export * from "./LoadingRepositoryFactory";
|
|
1
|
+
export type * from "./ILoadingRepository.js";
|
|
2
|
+
export * from "./LoadingRepository.js";
|
|
3
|
+
export * from "./LoadingRepositoryFactory.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./ILoadingRepository\";\nexport * from \"./LoadingRepository\";\nexport * from \"./LoadingRepositoryFactory\";\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export type * from \"./ILoadingRepository.js\";\nexport * from \"./LoadingRepository.js\";\nexport * from \"./LoadingRepositoryFactory.js\";\n"],"mappings":"AACA;AACA","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["IMetaRepository.ts"],"sourcesContent":["import type { Meta } from \"../../Models\";\n\nexport interface IMetaRepository {\n get: () => Meta;\n set: (meta: Meta) => Promise<void>;\n increaseTotalCount: (count?: number) => Promise<void>;\n decreaseTotalCount: (count?: number) => Promise<void>;\n}\n"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["IMetaRepository.ts"],"sourcesContent":["import type { Meta } from \"../../Models/index.js\";\n\nexport interface IMetaRepository {\n get: () => Meta;\n set: (meta: Meta) => Promise<void>;\n increaseTotalCount: (count?: number) => Promise<void>;\n decreaseTotalCount: (count?: number) => Promise<void>;\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { IMetaRepository } from "./IMetaRepository";
|
|
2
|
-
import type { MetaDTO } from "
|
|
1
|
+
import type { IMetaRepository } from "./IMetaRepository.js";
|
|
2
|
+
import type { MetaDTO } from "../../../../fta/Domain/Models/Meta/index.js";
|
|
3
3
|
export declare class MetaRepository implements IMetaRepository {
|
|
4
4
|
private meta;
|
|
5
5
|
constructor();
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { makeAutoObservable, runInAction } from "mobx";
|
|
2
2
|
import { decodeCursor, encodeCursor } from "@webiny/utils";
|
|
3
|
-
import { Meta, MetaMapper } from "../../Models/Meta";
|
|
3
|
+
import { Meta, MetaMapper } from "../../Models/Meta/index.js";
|
|
4
4
|
export class MetaRepository {
|
|
5
5
|
constructor() {
|
|
6
6
|
this.meta = Meta.createEmpty();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["makeAutoObservable","runInAction","decodeCursor","encodeCursor","Meta","MetaMapper","MetaRepository","constructor","meta","createEmpty","set","create","get","toDto","decreaseTotalCount","count","updateMetaOnColumnDeltaChange","increaseTotalCount","countDelta","current","totalCount","cursorDecoded","cursor","newCursorDecoded","String","Number"],"sources":["MetaRepository.ts"],"sourcesContent":["import { makeAutoObservable, runInAction } from \"mobx\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils\";\nimport type { IMetaRepository } from \"./IMetaRepository\";\nimport type { MetaDTO } from \"~/fta/Domain/Models/Meta\";\nimport { Meta, MetaMapper } from \"~/fta/Domain/Models/Meta\";\n\nexport class MetaRepository implements IMetaRepository {\n private meta: Meta;\n\n constructor() {\n this.meta = Meta.createEmpty();\n makeAutoObservable(this);\n }\n\n async set(meta: MetaDTO) {\n runInAction(() => {\n this.meta = Meta.create(meta);\n });\n }\n\n get() {\n return MetaMapper.toDto(this.meta);\n }\n\n async decreaseTotalCount(count = 1) {\n return await this.updateMetaOnColumnDeltaChange(-count);\n }\n\n async increaseTotalCount(count = 1) {\n return await this.updateMetaOnColumnDeltaChange(count);\n }\n\n private async updateMetaOnColumnDeltaChange(countDelta: number) {\n // Retrieve the current meta\n const current = this.get();\n\n // Calculate the new totalCount based on the delta change\n const totalCount = current.totalCount + countDelta;\n\n // Calculate the new cursor position based on the delta change\n const cursorDecoded = decodeCursor(current.cursor);\n const newCursorDecoded = String(Number(cursorDecoded) + countDelta);\n const cursor = encodeCursor(newCursorDecoded);\n\n // Update the meta with the new totalCount and cursor\n return await this.set({ ...current, totalCount, cursor });\n }\n}\n"],"mappings":"AAAA,SAASA,kBAAkB,EAAEC,WAAW,QAAQ,MAAM;AACtD,SAASC,YAAY,EAAEC,YAAY,QAAQ,eAAe;AAG1D,SAASC,IAAI,EAAEC,UAAU;AAEzB,OAAO,MAAMC,cAAc,CAA4B;EAGnDC,WAAWA,CAAA,EAAG;IACV,IAAI,CAACC,IAAI,GAAGJ,IAAI,CAACK,WAAW,CAAC,CAAC;IAC9BT,kBAAkB,CAAC,IAAI,CAAC;EAC5B;EAEA,MAAMU,GAAGA,CAACF,IAAa,EAAE;IACrBP,WAAW,CAAC,MAAM;MACd,IAAI,CAACO,IAAI,GAAGJ,IAAI,CAACO,MAAM,CAACH,IAAI,CAAC;IACjC,CAAC,CAAC;EACN;EAEAI,GAAGA,CAAA,EAAG;IACF,OAAOP,UAAU,CAACQ,KAAK,CAAC,IAAI,CAACL,IAAI,CAAC;EACtC;EAEA,MAAMM,kBAAkBA,CAACC,KAAK,GAAG,CAAC,EAAE;IAChC,OAAO,MAAM,IAAI,CAACC,6BAA6B,CAAC,CAACD,KAAK,CAAC;EAC3D;EAEA,MAAME,kBAAkBA,CAACF,KAAK,GAAG,CAAC,EAAE;IAChC,OAAO,MAAM,IAAI,CAACC,6BAA6B,CAACD,KAAK,CAAC;EAC1D;EAEA,MAAcC,6BAA6BA,CAACE,UAAkB,EAAE;IAC5D;IACA,MAAMC,OAAO,GAAG,IAAI,CAACP,GAAG,CAAC,CAAC;;IAE1B;IACA,MAAMQ,UAAU,GAAGD,OAAO,CAACC,UAAU,GAAGF,UAAU;;IAElD;IACA,MAAMG,aAAa,GAAGnB,YAAY,CAACiB,OAAO,CAACG,MAAM,CAAC;IAClD,MAAMC,gBAAgB,GAAGC,MAAM,CAACC,MAAM,CAACJ,aAAa,CAAC,GAAGH,UAAU,CAAC;IACnE,MAAMI,MAAM,GAAGnB,YAAY,CAACoB,gBAAgB,CAAC;;IAE7C;IACA,OAAO,MAAM,IAAI,CAACb,GAAG,CAAC;MAAE,GAAGS,OAAO;MAAEC,UAAU;MAAEE;IAAO,CAAC,CAAC;EAC7D;AACJ","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["makeAutoObservable","runInAction","decodeCursor","encodeCursor","Meta","MetaMapper","MetaRepository","constructor","meta","createEmpty","set","create","get","toDto","decreaseTotalCount","count","updateMetaOnColumnDeltaChange","increaseTotalCount","countDelta","current","totalCount","cursorDecoded","cursor","newCursorDecoded","String","Number"],"sources":["MetaRepository.ts"],"sourcesContent":["import { makeAutoObservable, runInAction } from \"mobx\";\nimport { decodeCursor, encodeCursor } from \"@webiny/utils\";\nimport type { IMetaRepository } from \"./IMetaRepository.js\";\nimport type { MetaDTO } from \"~/fta/Domain/Models/Meta/index.js\";\nimport { Meta, MetaMapper } from \"~/fta/Domain/Models/Meta/index.js\";\n\nexport class MetaRepository implements IMetaRepository {\n private meta: Meta;\n\n constructor() {\n this.meta = Meta.createEmpty();\n makeAutoObservable(this);\n }\n\n async set(meta: MetaDTO) {\n runInAction(() => {\n this.meta = Meta.create(meta);\n });\n }\n\n get() {\n return MetaMapper.toDto(this.meta);\n }\n\n async decreaseTotalCount(count = 1) {\n return await this.updateMetaOnColumnDeltaChange(-count);\n }\n\n async increaseTotalCount(count = 1) {\n return await this.updateMetaOnColumnDeltaChange(count);\n }\n\n private async updateMetaOnColumnDeltaChange(countDelta: number) {\n // Retrieve the current meta\n const current = this.get();\n\n // Calculate the new totalCount based on the delta change\n const totalCount = current.totalCount + countDelta;\n\n // Calculate the new cursor position based on the delta change\n const cursorDecoded = decodeCursor(current.cursor);\n const newCursorDecoded = String(Number(cursorDecoded) + countDelta);\n const cursor = encodeCursor(newCursorDecoded);\n\n // Update the meta with the new totalCount and cursor\n return await this.set({ ...current, totalCount, cursor });\n }\n}\n"],"mappings":"AAAA,SAASA,kBAAkB,EAAEC,WAAW,QAAQ,MAAM;AACtD,SAASC,YAAY,EAAEC,YAAY,QAAQ,eAAe;AAG1D,SAASC,IAAI,EAAEC,UAAU;AAEzB,OAAO,MAAMC,cAAc,CAA4B;EAGnDC,WAAWA,CAAA,EAAG;IACV,IAAI,CAACC,IAAI,GAAGJ,IAAI,CAACK,WAAW,CAAC,CAAC;IAC9BT,kBAAkB,CAAC,IAAI,CAAC;EAC5B;EAEA,MAAMU,GAAGA,CAACF,IAAa,EAAE;IACrBP,WAAW,CAAC,MAAM;MACd,IAAI,CAACO,IAAI,GAAGJ,IAAI,CAACO,MAAM,CAACH,IAAI,CAAC;IACjC,CAAC,CAAC;EACN;EAEAI,GAAGA,CAAA,EAAG;IACF,OAAOP,UAAU,CAACQ,KAAK,CAAC,IAAI,CAACL,IAAI,CAAC;EACtC;EAEA,MAAMM,kBAAkBA,CAACC,KAAK,GAAG,CAAC,EAAE;IAChC,OAAO,MAAM,IAAI,CAACC,6BAA6B,CAAC,CAACD,KAAK,CAAC;EAC3D;EAEA,MAAME,kBAAkBA,CAACF,KAAK,GAAG,CAAC,EAAE;IAChC,OAAO,MAAM,IAAI,CAACC,6BAA6B,CAACD,KAAK,CAAC;EAC1D;EAEA,MAAcC,6BAA6BA,CAACE,UAAkB,EAAE;IAC5D;IACA,MAAMC,OAAO,GAAG,IAAI,CAACP,GAAG,CAAC,CAAC;;IAE1B;IACA,MAAMQ,UAAU,GAAGD,OAAO,CAACC,UAAU,GAAGF,UAAU;;IAElD;IACA,MAAMG,aAAa,GAAGnB,YAAY,CAACiB,OAAO,CAACG,MAAM,CAAC;IAClD,MAAMC,gBAAgB,GAAGC,MAAM,CAACC,MAAM,CAACJ,aAAa,CAAC,GAAGH,UAAU,CAAC;IACnE,MAAMI,MAAM,GAAGnB,YAAY,CAACoB,gBAAgB,CAAC;;IAE7C;IACA,OAAO,MAAM,IAAI,CAACb,GAAG,CAAC;MAAE,GAAGS,OAAO;MAAEC,UAAU;MAAEE;IAAO,CAAC,CAAC;EAC7D;AACJ","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["MetaRepository","MetaRepositoryFactory","cache","Map","getRepository","namespace","cacheKey","getCacheKey","has","set","get","Date","now","toString","metaRepositoryFactory"],"sources":["MetaRepositoryFactory.ts"],"sourcesContent":["import { MetaRepository } from \"./MetaRepository\";\n\nexport class MetaRepositoryFactory {\n private cache: Map<string, MetaRepository> = new Map();\n\n getRepository(namespace?: string) {\n const cacheKey = this.getCacheKey(namespace);\n\n if (!this.cache.has(cacheKey)) {\n this.cache.set(cacheKey, new MetaRepository());\n }\n\n return this.cache.get(cacheKey) as MetaRepository;\n }\n\n private getCacheKey(namespace?: string) {\n return namespace ?? Date.now().toString();\n }\n}\n\nexport const metaRepositoryFactory = new MetaRepositoryFactory();\n"],"mappings":"AAAA,SAASA,cAAc;AAEvB,OAAO,MAAMC,qBAAqB,CAAC;EACvBC,KAAK,GAAgC,IAAIC,GAAG,CAAC,CAAC;EAEtDC,aAAaA,CAACC,SAAkB,EAAE;IAC9B,MAAMC,QAAQ,GAAG,IAAI,CAACC,WAAW,CAACF,SAAS,CAAC;IAE5C,IAAI,CAAC,IAAI,CAACH,KAAK,CAACM,GAAG,CAACF,QAAQ,CAAC,EAAE;MAC3B,IAAI,CAACJ,KAAK,CAACO,GAAG,CAACH,QAAQ,EAAE,IAAIN,cAAc,CAAC,CAAC,CAAC;IAClD;IAEA,OAAO,IAAI,CAACE,KAAK,CAACQ,GAAG,CAACJ,QAAQ,CAAC;EACnC;EAEQC,WAAWA,CAACF,SAAkB,EAAE;IACpC,OAAOA,SAAS,IAAIM,IAAI,CAACC,GAAG,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EAC7C;AACJ;AAEA,OAAO,MAAMC,qBAAqB,GAAG,IAAIb,qBAAqB,CAAC,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["MetaRepository","MetaRepositoryFactory","cache","Map","getRepository","namespace","cacheKey","getCacheKey","has","set","get","Date","now","toString","metaRepositoryFactory"],"sources":["MetaRepositoryFactory.ts"],"sourcesContent":["import { MetaRepository } from \"./MetaRepository.js\";\n\nexport class MetaRepositoryFactory {\n private cache: Map<string, MetaRepository> = new Map();\n\n getRepository(namespace?: string) {\n const cacheKey = this.getCacheKey(namespace);\n\n if (!this.cache.has(cacheKey)) {\n this.cache.set(cacheKey, new MetaRepository());\n }\n\n return this.cache.get(cacheKey) as MetaRepository;\n }\n\n private getCacheKey(namespace?: string) {\n return namespace ?? Date.now().toString();\n }\n}\n\nexport const metaRepositoryFactory = new MetaRepositoryFactory();\n"],"mappings":"AAAA,SAASA,cAAc;AAEvB,OAAO,MAAMC,qBAAqB,CAAC;EACvBC,KAAK,GAAgC,IAAIC,GAAG,CAAC,CAAC;EAEtDC,aAAaA,CAACC,SAAkB,EAAE;IAC9B,MAAMC,QAAQ,GAAG,IAAI,CAACC,WAAW,CAACF,SAAS,CAAC;IAE5C,IAAI,CAAC,IAAI,CAACH,KAAK,CAACM,GAAG,CAACF,QAAQ,CAAC,EAAE;MAC3B,IAAI,CAACJ,KAAK,CAACO,GAAG,CAACH,QAAQ,EAAE,IAAIN,cAAc,CAAC,CAAC,CAAC;IAClD;IAEA,OAAO,IAAI,CAACE,KAAK,CAACQ,GAAG,CAACJ,QAAQ,CAAC;EACnC;EAEQC,WAAWA,CAACF,SAAkB,EAAE;IACpC,OAAOA,SAAS,IAAIM,IAAI,CAACC,GAAG,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EAC7C;AACJ;AAEA,OAAO,MAAMC,qBAAqB,GAAG,IAAIb,qBAAqB,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./IMetaRepository";
|
|
2
|
-
export * from "./MetaRepository";
|
|
3
|
-
export * from "./MetaRepositoryFactory";
|
|
1
|
+
export type * from "./IMetaRepository.js";
|
|
2
|
+
export * from "./MetaRepository.js";
|
|
3
|
+
export * from "./MetaRepositoryFactory.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./IMetaRepository\";\nexport * from \"./MetaRepository\";\nexport * from \"./MetaRepositoryFactory\";\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export type * from \"./IMetaRepository.js\";\nexport * from \"./MetaRepository.js\";\nexport * from \"./MetaRepositoryFactory.js\";\n"],"mappings":"AACA;AACA","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["ISortingRepository.ts"],"sourcesContent":["import type { Sorting } from \"~/fta/Domain/Models\";\n\nexport interface ISortingRepository {\n set: (sorts: Sorting[]) => Promise<void>;\n get: () => Sorting[];\n}\n"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["ISortingRepository.ts"],"sourcesContent":["import type { Sorting } from \"~/fta/Domain/Models/index.js\";\n\nexport interface ISortingRepository {\n set: (sorts: Sorting[]) => Promise<void>;\n get: () => Sorting[];\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { ISortingRepository } from "./ISortingRepository";
|
|
2
|
-
import type { Sorting } from "
|
|
1
|
+
import type { ISortingRepository } from "./ISortingRepository.js";
|
|
2
|
+
import type { Sorting } from "../../../../fta/Domain/Models/index.js";
|
|
3
3
|
export declare class SortingRepository implements ISortingRepository {
|
|
4
4
|
private sorting;
|
|
5
5
|
constructor();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["makeAutoObservable","SortingRepository","sorting","constructor","get","set","sorts"],"sources":["SortingRepository.ts"],"sourcesContent":["import { makeAutoObservable } from \"mobx\";\nimport type { ISortingRepository } from \"./ISortingRepository\";\nimport type { Sorting } from \"~/fta/Domain/Models\";\n\nexport class SortingRepository implements ISortingRepository {\n private sorting: Sorting[] = [];\n\n constructor() {\n makeAutoObservable(this);\n }\n\n get() {\n return this.sorting;\n }\n\n async set(sorts: Sorting[]) {\n this.sorting = sorts;\n }\n}\n"],"mappings":"AAAA,SAASA,kBAAkB,QAAQ,MAAM;AAIzC,OAAO,MAAMC,iBAAiB,CAA+B;EACjDC,OAAO,GAAc,EAAE;EAE/BC,WAAWA,CAAA,EAAG;IACVH,kBAAkB,CAAC,IAAI,CAAC;EAC5B;EAEAI,GAAGA,CAAA,EAAG;IACF,OAAO,IAAI,CAACF,OAAO;EACvB;EAEA,MAAMG,GAAGA,CAACC,KAAgB,EAAE;IACxB,IAAI,CAACJ,OAAO,GAAGI,KAAK;EACxB;AACJ","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["makeAutoObservable","SortingRepository","sorting","constructor","get","set","sorts"],"sources":["SortingRepository.ts"],"sourcesContent":["import { makeAutoObservable } from \"mobx\";\nimport type { ISortingRepository } from \"./ISortingRepository.js\";\nimport type { Sorting } from \"~/fta/Domain/Models/index.js\";\n\nexport class SortingRepository implements ISortingRepository {\n private sorting: Sorting[] = [];\n\n constructor() {\n makeAutoObservable(this);\n }\n\n get() {\n return this.sorting;\n }\n\n async set(sorts: Sorting[]) {\n this.sorting = sorts;\n }\n}\n"],"mappings":"AAAA,SAASA,kBAAkB,QAAQ,MAAM;AAIzC,OAAO,MAAMC,iBAAiB,CAA+B;EACjDC,OAAO,GAAc,EAAE;EAE/BC,WAAWA,CAAA,EAAG;IACVH,kBAAkB,CAAC,IAAI,CAAC;EAC5B;EAEAI,GAAGA,CAAA,EAAG;IACF,OAAO,IAAI,CAACF,OAAO;EACvB;EAEA,MAAMG,GAAGA,CAACC,KAAgB,EAAE;IACxB,IAAI,CAACJ,OAAO,GAAGI,KAAK;EACxB;AACJ","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["SortingRepository","SortingRepositoryFactory","cache","Map","getRepository","namespace","cacheKey","getCacheKey","has","set","get","Date","now","toString","sortRepositoryFactory"],"sources":["SortingRepositoryFactory.ts"],"sourcesContent":["import { SortingRepository } from \"./SortingRepository\";\nimport type { ISortingRepository } from \"~/fta/index.js\";\n\nexport class SortingRepositoryFactory {\n private cache: Map<string, ISortingRepository> = new Map();\n\n getRepository(namespace?: string) {\n const cacheKey = this.getCacheKey(namespace);\n\n if (!this.cache.has(cacheKey)) {\n this.cache.set(cacheKey, new SortingRepository());\n }\n\n return this.cache.get(cacheKey) as ISortingRepository;\n }\n\n private getCacheKey(namespace?: string) {\n return namespace ?? Date.now().toString();\n }\n}\n\nexport const sortRepositoryFactory = new SortingRepositoryFactory();\n"],"mappings":"AAAA,SAASA,iBAAiB;AAG1B,OAAO,MAAMC,wBAAwB,CAAC;EAC1BC,KAAK,GAAoC,IAAIC,GAAG,CAAC,CAAC;EAE1DC,aAAaA,CAACC,SAAkB,EAAE;IAC9B,MAAMC,QAAQ,GAAG,IAAI,CAACC,WAAW,CAACF,SAAS,CAAC;IAE5C,IAAI,CAAC,IAAI,CAACH,KAAK,CAACM,GAAG,CAACF,QAAQ,CAAC,EAAE;MAC3B,IAAI,CAACJ,KAAK,CAACO,GAAG,CAACH,QAAQ,EAAE,IAAIN,iBAAiB,CAAC,CAAC,CAAC;IACrD;IAEA,OAAO,IAAI,CAACE,KAAK,CAACQ,GAAG,CAACJ,QAAQ,CAAC;EACnC;EAEQC,WAAWA,CAACF,SAAkB,EAAE;IACpC,OAAOA,SAAS,IAAIM,IAAI,CAACC,GAAG,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EAC7C;AACJ;AAEA,OAAO,MAAMC,qBAAqB,GAAG,IAAIb,wBAAwB,CAAC,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["SortingRepository","SortingRepositoryFactory","cache","Map","getRepository","namespace","cacheKey","getCacheKey","has","set","get","Date","now","toString","sortRepositoryFactory"],"sources":["SortingRepositoryFactory.ts"],"sourcesContent":["import { SortingRepository } from \"./SortingRepository.js\";\nimport type { ISortingRepository } from \"~/fta/index.js\";\n\nexport class SortingRepositoryFactory {\n private cache: Map<string, ISortingRepository> = new Map();\n\n getRepository(namespace?: string) {\n const cacheKey = this.getCacheKey(namespace);\n\n if (!this.cache.has(cacheKey)) {\n this.cache.set(cacheKey, new SortingRepository());\n }\n\n return this.cache.get(cacheKey) as ISortingRepository;\n }\n\n private getCacheKey(namespace?: string) {\n return namespace ?? Date.now().toString();\n }\n}\n\nexport const sortRepositoryFactory = new SortingRepositoryFactory();\n"],"mappings":"AAAA,SAASA,iBAAiB;AAG1B,OAAO,MAAMC,wBAAwB,CAAC;EAC1BC,KAAK,GAAoC,IAAIC,GAAG,CAAC,CAAC;EAE1DC,aAAaA,CAACC,SAAkB,EAAE;IAC9B,MAAMC,QAAQ,GAAG,IAAI,CAACC,WAAW,CAACF,SAAS,CAAC;IAE5C,IAAI,CAAC,IAAI,CAACH,KAAK,CAACM,GAAG,CAACF,QAAQ,CAAC,EAAE;MAC3B,IAAI,CAACJ,KAAK,CAACO,GAAG,CAACH,QAAQ,EAAE,IAAIN,iBAAiB,CAAC,CAAC,CAAC;IACrD;IAEA,OAAO,IAAI,CAACE,KAAK,CAACQ,GAAG,CAACJ,QAAQ,CAAC;EACnC;EAEQC,WAAWA,CAACF,SAAkB,EAAE;IACpC,OAAOA,SAAS,IAAIM,IAAI,CAACC,GAAG,CAAC,CAAC,CAACC,QAAQ,CAAC,CAAC;EAC7C;AACJ;AAEA,OAAO,MAAMC,qBAAqB,GAAG,IAAIb,wBAAwB,CAAC,CAAC","ignoreList":[]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./ISortingRepository";
|
|
2
|
-
export * from "./SortingRepository";
|
|
3
|
-
export * from "./SortingRepositoryFactory";
|
|
1
|
+
export type * from "./ISortingRepository.js";
|
|
2
|
+
export * from "./SortingRepository.js";
|
|
3
|
+
export * from "./SortingRepositoryFactory.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./ISortingRepository\";\nexport * from \"./SortingRepository\";\nexport * from \"./SortingRepositoryFactory\";\n"],"mappings":"
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export type * from \"./ISortingRepository.js\";\nexport * from \"./SortingRepository.js\";\nexport * from \"./SortingRepositoryFactory.js\";\n"],"mappings":"AACA;AACA","ignoreList":[]}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./Loading";
|
|
2
|
-
export * from "./Meta";
|
|
3
|
-
export * from "./Sorting";
|
|
1
|
+
export * from "./Loading/index.js";
|
|
2
|
+
export * from "./Meta/index.js";
|
|
3
|
+
export * from "./Sorting/index.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Loading\";\nexport * from \"./Meta\";\nexport * from \"./Sorting\";\n"],"mappings":"AAAA;AACA;AACA","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Loading/index.js\";\nexport * from \"./Meta/index.js\";\nexport * from \"./Sorting/index.js\";\n"],"mappings":"AAAA;AACA;AACA","ignoreList":[]}
|
package/fta/Domain/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from "./Models";
|
|
2
|
-
export * from "./Repositories";
|
|
1
|
+
export * from "./Models/index.js";
|
|
2
|
+
export * from "./Repositories/index.js";
|
package/fta/Domain/index.js
CHANGED
package/fta/Domain/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Models\";\nexport * from \"./Repositories\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Models/index.js\";\nexport * from \"./Repositories/index.js\";\n"],"mappings":"AAAA;AACA","ignoreList":[]}
|
package/fta/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from "./Domain";
|
|
1
|
+
export * from "./Domain/index.js";
|
package/fta/index.js
CHANGED
package/fta/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Domain\";\n"],"mappings":"AAAA","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Domain/index.js\";\n"],"mappings":"AAAA","ignoreList":[]}
|
package/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from "./fta";
|
|
1
|
+
export * from "./fta/index.js";
|
package/index.js
CHANGED
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./fta\";\n"],"mappings":"AAAA","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./fta/index.js\";\n"],"mappings":"AAAA","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/app-utils",
|
|
3
|
-
"version": "6.0.0-
|
|
3
|
+
"version": "6.0.0-rc.0",
|
|
4
|
+
"type": "module",
|
|
4
5
|
"main": "index.js",
|
|
5
6
|
"repository": {
|
|
6
7
|
"type": "git",
|
|
@@ -10,20 +11,17 @@
|
|
|
10
11
|
"author": "Webiny Ltd.",
|
|
11
12
|
"license": "MIT",
|
|
12
13
|
"dependencies": {
|
|
13
|
-
"@webiny/
|
|
14
|
-
"
|
|
14
|
+
"@webiny/feature": "6.0.0-rc.0",
|
|
15
|
+
"@webiny/utils": "6.0.0-rc.0",
|
|
16
|
+
"mobx": "6.15.0"
|
|
15
17
|
},
|
|
16
18
|
"devDependencies": {
|
|
17
|
-
"@webiny/
|
|
18
|
-
"typescript": "5.
|
|
19
|
+
"@webiny/build-tools": "6.0.0-rc.0",
|
|
20
|
+
"typescript": "5.9.3"
|
|
19
21
|
},
|
|
20
22
|
"publishConfig": {
|
|
21
23
|
"access": "public",
|
|
22
24
|
"directory": "dist"
|
|
23
25
|
},
|
|
24
|
-
"
|
|
25
|
-
"build": "node ../cli/bin.js run build",
|
|
26
|
-
"watch": "node ../cli/bin.js run watch"
|
|
27
|
-
},
|
|
28
|
-
"gitHead": "b7e120541b093e91f214904a9f13e4c2c4640978"
|
|
26
|
+
"gitHead": "0f2aa699f4642e550ab62c96fcd050e8d02345c9"
|
|
29
27
|
}
|