@dereekb/dbx-firebase 12.0.4 → 12.0.6
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/esm2022/lib/auth/login/login.anonymous.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.apple.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.button.component.mjs +16 -19
- package/esm2022/lib/auth/login/login.context.back.component.mjs +5 -7
- package/esm2022/lib/auth/login/login.email.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.email.content.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.facebook.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.github.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.google.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.microsoft.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.terms.simple.component.mjs +1 -1
- package/esm2022/lib/auth/login/login.twitter.component.mjs +1 -1
- package/esm2022/lib/auth/login/register.component.mjs +9 -15
- package/esm2022/lib/auth/login/register.email.component.mjs +1 -1
- package/esm2022/lib/model/modules/model/model.types.module.mjs +5 -5
- package/esm2022/lib/model/modules/model/model.types.view.directive.mjs +5 -5
- package/esm2022/lib/model/modules/store/store.collection.directive.mjs +26 -21
- package/esm2022/lib/model/modules/store/store.document.directive.mjs +47 -34
- package/esm2022/lib/model/modules/store/store.subcollection.directive.mjs +23 -9
- package/fesm2022/dereekb-dbx-firebase.mjs +128 -111
- package/fesm2022/dereekb-dbx-firebase.mjs.map +1 -1
- package/lib/auth/login/login.button.component.d.ts +4 -5
- package/lib/auth/login/login.context.back.component.d.ts +1 -2
- package/lib/auth/login/register.component.d.ts +4 -5
- package/lib/model/modules/model/model.types.module.d.ts +2 -2
- package/lib/model/modules/model/model.types.view.directive.d.ts +3 -3
- package/lib/model/modules/store/store.collection.directive.d.ts +11 -5
- package/lib/model/modules/store/store.document.directive.d.ts +17 -6
- package/lib/model/modules/store/store.subcollection.directive.d.ts +9 -4
- package/package.json +1 -1
|
@@ -1,22 +1,37 @@
|
|
|
1
|
-
import { Directive, forwardRef,
|
|
1
|
+
import { Directive, forwardRef, model } from '@angular/core';
|
|
2
2
|
import { BehaviorSubject, shareReplay, switchMap } from 'rxjs';
|
|
3
|
-
import { filterMaybe } from '@dereekb/rxjs';
|
|
3
|
+
import { filterMaybe, skipInitialMaybe, SubscriptionObject } from '@dereekb/rxjs';
|
|
4
|
+
import { toObservable } from '@angular/core/rxjs-interop';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
/**
|
|
6
7
|
* Abstract directive that contains a DbxFirebaseCollectionStore and provides an interface for communicating with other directives.
|
|
7
8
|
*/
|
|
8
9
|
export class DbxFirebaseCollectionStoreDirective {
|
|
10
|
+
maxPages = model(undefined);
|
|
11
|
+
itemsPerPage = model(undefined);
|
|
12
|
+
contraints = model(undefined);
|
|
13
|
+
_maxPages = toObservable(this.maxPages).pipe(skipInitialMaybe());
|
|
14
|
+
_itemsPerPage = toObservable(this.itemsPerPage).pipe(skipInitialMaybe());
|
|
15
|
+
_constraints = toObservable(this.contraints).pipe(skipInitialMaybe());
|
|
9
16
|
_store = new BehaviorSubject(undefined);
|
|
17
|
+
_storeSub = new SubscriptionObject();
|
|
10
18
|
store$ = this._store.pipe(filterMaybe(), shareReplay(1));
|
|
11
19
|
pageLoadingState$ = this.store$.pipe(switchMap((x) => x.pageLoadingState$));
|
|
12
20
|
constructor(store) {
|
|
13
21
|
this.replaceStore(store);
|
|
22
|
+
// sync inputs to store any time the store changes
|
|
23
|
+
this._storeSub.subscription = this.store$.subscribe((x) => {
|
|
24
|
+
x.setConstraints(this._constraints);
|
|
25
|
+
x.setMaxPages(this._maxPages);
|
|
26
|
+
x.setItemsPerPage(this._itemsPerPage);
|
|
27
|
+
});
|
|
14
28
|
}
|
|
15
29
|
get store() {
|
|
16
30
|
return this._store.value;
|
|
17
31
|
}
|
|
18
32
|
ngOnDestroy() {
|
|
19
33
|
this._store.complete();
|
|
34
|
+
this._storeSub.destroy();
|
|
20
35
|
}
|
|
21
36
|
/**
|
|
22
37
|
* Replaces the internal store.
|
|
@@ -24,15 +39,14 @@ export class DbxFirebaseCollectionStoreDirective {
|
|
|
24
39
|
replaceStore(store) {
|
|
25
40
|
this._store.next(store);
|
|
26
41
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
this.store.setMaxPages(maxPages);
|
|
42
|
+
setMaxPages(maxPages) {
|
|
43
|
+
this.maxPages.set(maxPages);
|
|
30
44
|
}
|
|
31
|
-
|
|
32
|
-
this.
|
|
45
|
+
setItemsPerPage(itemsPerPage) {
|
|
46
|
+
this.itemsPerPage.set(itemsPerPage);
|
|
33
47
|
}
|
|
34
|
-
|
|
35
|
-
this.
|
|
48
|
+
setConstraints(constraints) {
|
|
49
|
+
this.contraints.set(constraints);
|
|
36
50
|
}
|
|
37
51
|
next() {
|
|
38
52
|
this.store.next();
|
|
@@ -40,21 +54,12 @@ export class DbxFirebaseCollectionStoreDirective {
|
|
|
40
54
|
restart() {
|
|
41
55
|
this.store.restart();
|
|
42
56
|
}
|
|
43
|
-
setConstraints(constraints) {
|
|
44
|
-
this.store.setConstraints(constraints);
|
|
45
|
-
}
|
|
46
57
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseCollectionStoreDirective, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
|
|
47
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
58
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFirebaseCollectionStoreDirective, inputs: { maxPages: { classPropertyName: "maxPages", publicName: "maxPages", isSignal: true, isRequired: false, transformFunction: null }, itemsPerPage: { classPropertyName: "itemsPerPage", publicName: "itemsPerPage", isSignal: true, isRequired: false, transformFunction: null }, contraints: { classPropertyName: "contraints", publicName: "contraints", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { maxPages: "maxPagesChange", itemsPerPage: "itemsPerPageChange", contraints: "contraintsChange" }, ngImport: i0 });
|
|
48
59
|
}
|
|
49
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseCollectionStoreDirective, decorators: [{
|
|
50
61
|
type: Directive
|
|
51
|
-
}], ctorParameters: () => [{ type: undefined }]
|
|
52
|
-
type: Input
|
|
53
|
-
}], itemsPerPage: [{
|
|
54
|
-
type: Input
|
|
55
|
-
}], constraints: [{
|
|
56
|
-
type: Input
|
|
57
|
-
}] } });
|
|
62
|
+
}], ctorParameters: () => [{ type: undefined }] });
|
|
58
63
|
export function provideDbxFirebaseCollectionStoreDirective(sourceType, storeType) {
|
|
59
64
|
const providers = [
|
|
60
65
|
{
|
|
@@ -67,4 +72,4 @@ export function provideDbxFirebaseCollectionStoreDirective(sourceType, storeType
|
|
|
67
72
|
}
|
|
68
73
|
return providers;
|
|
69
74
|
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store.collection.directive.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-firebase/src/lib/model/modules/store/store.collection.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAA6B,MAAM,eAAe,CAAC;AAIxF,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;;AAE1D;;GAEG;AAEH,MAAM,OAAgB,mCAAmC;IAC9C,QAAQ,GAAG,KAAK,CAAgB,SAAS,CAAC,CAAC;IAC3C,YAAY,GAAG,KAAK,CAAgB,SAAS,CAAC,CAAC;IAC/C,UAAU,GAAG,KAAK,CAAgD,SAAS,CAAC,CAAC;IAErE,SAAS,GAAG,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACjE,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACzE,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAEtE,MAAM,GAAG,IAAI,eAAe,CAAW,SAAS,CAAC,CAAC;IAClD,SAAS,GAAG,IAAI,kBAAkB,EAAE,CAAC;IAE7C,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IACzD,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAErF,YAAY,KAAQ;QAClB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAEzB,kDAAkD;QAClD,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACxD,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACpC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC9B,CAAC,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,KAAU,CAAC;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,KAAQ;QACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,WAAW,CAAC,QAAuB;QACjC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAC9B,CAAC;IAED,eAAe,CAAC,YAA2B;QACzC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IACtC,CAAC;IAED,cAAc,CAAC,WAA0D;QACvE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IACnC,CAAC;IAED,IAAI;QACF,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;IACvB,CAAC;wGA5DmB,mCAAmC;4FAAnC,mCAAmC;;4FAAnC,mCAAmC;kBADxD,SAAS;;AA4EV,MAAM,UAAU,0CAA0C,CAAgK,UAAmB,EAAE,SAAmB;IAChQ,MAAM,SAAS,GAAe;QAC5B;YACE,OAAO,EAAE,mCAAmC;YAC5C,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC;SAC1C;KACF,CAAC;IAEF,IAAI,SAAS,EAAE,CAAC;QACd,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC","sourcesContent":["import { Directive, forwardRef, model, OnDestroy, Provider, Type } from '@angular/core';\nimport { FirestoreDocument, FirestoreQueryConstraint } from '@dereekb/firebase';\nimport { Maybe, ArrayOrValue } from '@dereekb/util';\nimport { DbxFirebaseCollectionStore } from './store.collection';\nimport { BehaviorSubject, shareReplay, switchMap } from 'rxjs';\nimport { filterMaybe, skipInitialMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { toObservable } from '@angular/core/rxjs-interop';\n\n/**\n * Abstract directive that contains a DbxFirebaseCollectionStore and provides an interface for communicating with other directives.\n */\n@Directive()\nexport abstract class DbxFirebaseCollectionStoreDirective<T = unknown, D extends FirestoreDocument<T> = FirestoreDocument<T>, S extends DbxFirebaseCollectionStore<T, D> = DbxFirebaseCollectionStore<T, D>> implements OnDestroy {\n  readonly maxPages = model<Maybe<number>>(undefined);\n  readonly itemsPerPage = model<Maybe<number>>(undefined);\n  readonly contraints = model<Maybe<ArrayOrValue<FirestoreQueryConstraint>>>(undefined);\n\n  private readonly _maxPages = toObservable(this.maxPages).pipe(skipInitialMaybe());\n  private readonly _itemsPerPage = toObservable(this.itemsPerPage).pipe(skipInitialMaybe());\n  private readonly _constraints = toObservable(this.contraints).pipe(skipInitialMaybe());\n\n  private readonly _store = new BehaviorSubject<Maybe<S>>(undefined);\n  private readonly _storeSub = new SubscriptionObject();\n\n  readonly store$ = this._store.pipe(filterMaybe(), shareReplay(1));\n  readonly pageLoadingState$ = this.store$.pipe(switchMap((x) => x.pageLoadingState$));\n\n  constructor(store: S) {\n    this.replaceStore(store);\n\n    // sync inputs to store any time the store changes\n    this._storeSub.subscription = this.store$.subscribe((x) => {\n      x.setConstraints(this._constraints);\n      x.setMaxPages(this._maxPages);\n      x.setItemsPerPage(this._itemsPerPage);\n    });\n  }\n\n  get store() {\n    return this._store.value as S;\n  }\n\n  ngOnDestroy(): void {\n    this._store.complete();\n    this._storeSub.destroy();\n  }\n\n  /**\n   * Replaces the internal store.\n   */\n  replaceStore(store: S) {\n    this._store.next(store);\n  }\n\n  setMaxPages(maxPages: Maybe<number>) {\n    this.maxPages.set(maxPages);\n  }\n\n  setItemsPerPage(itemsPerPage: Maybe<number>) {\n    this.itemsPerPage.set(itemsPerPage);\n  }\n\n  setConstraints(constraints: Maybe<ArrayOrValue<FirestoreQueryConstraint>>) {\n    this.contraints.set(constraints);\n  }\n\n  next() {\n    this.store.next();\n  }\n\n  restart() {\n    this.store.restart();\n  }\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n// The use of any here does not degrade the type-safety; we want to simply match that the Store type S is used in the Directive type C to provide it.\n\n/**\n * Configures providers for a DbxFirebaseCollectionStoreDirective.\n *\n * Can optionally also provide the actual store type to include in the providers array so it is instantiated by Angular.\n *\n * @param sourceType\n */\nexport function provideDbxFirebaseCollectionStoreDirective<S extends DbxFirebaseCollectionStoreDirective<any, any, any>>(sourceType: Type<S>): Provider[];\nexport function provideDbxFirebaseCollectionStoreDirective<S extends DbxFirebaseCollectionStore<any, any>, C extends DbxFirebaseCollectionStoreDirective<any, any, S> = DbxFirebaseCollectionStoreDirective<any, any, S>>(sourceType: Type<C>, storeType?: Type<S>): Provider[];\nexport function provideDbxFirebaseCollectionStoreDirective<S extends DbxFirebaseCollectionStore<any, any>, C extends DbxFirebaseCollectionStoreDirective<any, any, S> = DbxFirebaseCollectionStoreDirective<any, any, S>>(sourceType: Type<C>, storeType?: Type<S>): Provider[] {\n  const providers: Provider[] = [\n    {\n      provide: DbxFirebaseCollectionStoreDirective,\n      useExisting: forwardRef(() => sourceType)\n    }\n  ];\n\n  if (storeType) {\n    providers.push(storeType);\n  }\n\n  return providers;\n}\n"]}
|
|
@@ -1,14 +1,26 @@
|
|
|
1
|
-
import { Directive, forwardRef,
|
|
1
|
+
import { Directive, forwardRef, model } from '@angular/core';
|
|
2
2
|
import { FirestoreAccessorStreamMode } from '@dereekb/firebase';
|
|
3
|
-
import { BehaviorSubject,
|
|
4
|
-
import { filterMaybe,
|
|
3
|
+
import { BehaviorSubject, shareReplay, switchMap } from 'rxjs';
|
|
4
|
+
import { filterMaybe, skipInitialMaybe, SubscriptionObject } from '@dereekb/rxjs';
|
|
5
5
|
import { provideDbxRouteModelIdDirectiveDelegate, provideDbxRouteModelKeyDirectiveDelegate } from '@dereekb/dbx-core';
|
|
6
|
+
import { toObservable } from '@angular/core/rxjs-interop';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
/**
|
|
8
9
|
* Abstract directive that contains a DbxFirebaseDocumentStore and provides an interface for communicating with other directives.
|
|
9
10
|
*/
|
|
10
11
|
export class DbxFirebaseDocumentStoreDirective {
|
|
12
|
+
documentId = model(undefined);
|
|
13
|
+
key = model(undefined);
|
|
14
|
+
flatKey = model(undefined);
|
|
15
|
+
ref = model(undefined);
|
|
16
|
+
streamMode = model(FirestoreAccessorStreamMode.STREAM);
|
|
17
|
+
_documentId$ = toObservable(this.documentId).pipe(skipInitialMaybe());
|
|
18
|
+
_key$ = toObservable(this.key).pipe(skipInitialMaybe());
|
|
19
|
+
_flatKey$ = toObservable(this.flatKey).pipe(skipInitialMaybe());
|
|
20
|
+
_ref$ = toObservable(this.ref).pipe(skipInitialMaybe());
|
|
21
|
+
_streamMode$ = toObservable(this.streamMode).pipe(skipInitialMaybe());
|
|
11
22
|
_store = new BehaviorSubject(undefined);
|
|
23
|
+
_storeSub = new SubscriptionObject();
|
|
12
24
|
store$ = this._store.pipe(filterMaybe(), shareReplay(1));
|
|
13
25
|
exists$ = this.store$.pipe(switchMap((x) => x.exists$));
|
|
14
26
|
document$ = this.store$.pipe(switchMap((x) => x.document$));
|
|
@@ -24,13 +36,40 @@ export class DbxFirebaseDocumentStoreDirective {
|
|
|
24
36
|
loadingState$ = this.store$.pipe(switchMap((x) => x.dataLoadingState$));
|
|
25
37
|
constructor(store) {
|
|
26
38
|
this.replaceStore(store);
|
|
39
|
+
// sync inputs to store any time the store changes
|
|
40
|
+
this._storeSub.subscription = this._store.subscribe((x) => {
|
|
41
|
+
if (x) {
|
|
42
|
+
x.setId(this._documentId$);
|
|
43
|
+
x.setKey(this._key$);
|
|
44
|
+
x.setFlatKey(this._flatKey$);
|
|
45
|
+
x.setRef(this._ref$);
|
|
46
|
+
x.setStreamMode(this._streamMode$);
|
|
47
|
+
}
|
|
48
|
+
});
|
|
27
49
|
}
|
|
28
50
|
ngOnDestroy() {
|
|
29
51
|
this._store.complete();
|
|
52
|
+
this._storeSub.destroy();
|
|
30
53
|
}
|
|
31
54
|
get store() {
|
|
32
55
|
return this._store.value;
|
|
33
56
|
}
|
|
57
|
+
// MARK: Setters
|
|
58
|
+
setDocumentId(documentId) {
|
|
59
|
+
this.documentId.set(documentId);
|
|
60
|
+
}
|
|
61
|
+
setKey(key) {
|
|
62
|
+
this.key.set(key);
|
|
63
|
+
}
|
|
64
|
+
setFlatKey(flatKey) {
|
|
65
|
+
this.flatKey.set(flatKey);
|
|
66
|
+
}
|
|
67
|
+
setRef(ref) {
|
|
68
|
+
this.ref.set(ref);
|
|
69
|
+
}
|
|
70
|
+
setStreamMode(streamMode) {
|
|
71
|
+
this.streamMode.set(streamMode);
|
|
72
|
+
}
|
|
34
73
|
/**
|
|
35
74
|
* Replaces the internal store.
|
|
36
75
|
*/
|
|
@@ -39,45 +78,19 @@ export class DbxFirebaseDocumentStoreDirective {
|
|
|
39
78
|
}
|
|
40
79
|
// MARK: DbxRouteModelIdDirectiveDelegate
|
|
41
80
|
useRouteModelIdParamsObservable(idFromParams) {
|
|
42
|
-
return
|
|
81
|
+
return idFromParams.subscribe((x) => this.setDocumentId(x));
|
|
43
82
|
}
|
|
44
83
|
// MARK: DbxRouteModelKeyDirectiveDelegate
|
|
45
84
|
useRouteModelKeyParamsObservable(keyFromParams) {
|
|
46
85
|
// we assume that the input model key is a TwoWayFlatFirestoreModelKey, since the TwoWayFlatFirestoreModelKey is safe to encode in the url
|
|
47
|
-
return
|
|
48
|
-
}
|
|
49
|
-
// MARK: Inputs
|
|
50
|
-
set documentId(documentId) {
|
|
51
|
-
useFirst(this.store$, (x) => x.setId(documentId));
|
|
52
|
-
}
|
|
53
|
-
set key(key) {
|
|
54
|
-
useFirst(this.store$, (x) => x.setKey(key));
|
|
55
|
-
}
|
|
56
|
-
set flatKey(flatKey) {
|
|
57
|
-
useFirst(this.store$, (x) => x.setFlatKey(flatKey));
|
|
58
|
-
}
|
|
59
|
-
set ref(ref) {
|
|
60
|
-
useFirst(this.store$, (x) => x.setRef(ref));
|
|
61
|
-
}
|
|
62
|
-
set streamMode(streamMode) {
|
|
63
|
-
useFirst(this.store$, (x) => x.setStreamMode(streamMode));
|
|
86
|
+
return keyFromParams.subscribe((x) => this.setFlatKey(x));
|
|
64
87
|
}
|
|
65
88
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseDocumentStoreDirective, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
|
|
66
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
89
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFirebaseDocumentStoreDirective, inputs: { documentId: { classPropertyName: "documentId", publicName: "documentId", isSignal: true, isRequired: false, transformFunction: null }, key: { classPropertyName: "key", publicName: "key", isSignal: true, isRequired: false, transformFunction: null }, flatKey: { classPropertyName: "flatKey", publicName: "flatKey", isSignal: true, isRequired: false, transformFunction: null }, ref: { classPropertyName: "ref", publicName: "ref", isSignal: true, isRequired: false, transformFunction: null }, streamMode: { classPropertyName: "streamMode", publicName: "streamMode", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { documentId: "documentIdChange", key: "keyChange", flatKey: "flatKeyChange", ref: "refChange", streamMode: "streamModeChange" }, ngImport: i0 });
|
|
67
90
|
}
|
|
68
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseDocumentStoreDirective, decorators: [{
|
|
69
92
|
type: Directive
|
|
70
|
-
}], ctorParameters: () => [{ type: undefined }]
|
|
71
|
-
type: Input
|
|
72
|
-
}], key: [{
|
|
73
|
-
type: Input
|
|
74
|
-
}], flatKey: [{
|
|
75
|
-
type: Input
|
|
76
|
-
}], ref: [{
|
|
77
|
-
type: Input
|
|
78
|
-
}], streamMode: [{
|
|
79
|
-
type: Input
|
|
80
|
-
}] } });
|
|
93
|
+
}], ctorParameters: () => [{ type: undefined }] });
|
|
81
94
|
export function provideDbxFirebaseDocumentStoreDirective(sourceType, storeType) {
|
|
82
95
|
const providers = [
|
|
83
96
|
{
|
|
@@ -92,4 +105,4 @@ export function provideDbxFirebaseDocumentStoreDirective(sourceType, storeType)
|
|
|
92
105
|
}
|
|
93
106
|
return providers;
|
|
94
107
|
}
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store.document.directive.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-firebase/src/lib/model/modules/store/store.document.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, forwardRef, Input, OnDestroy, Provider, Type } from '@angular/core';\nimport { DocumentReference, FirestoreAccessorStreamMode, FirestoreDocument, FirestoreModelKey, FirestoreModelId, TwoWayFlatFirestoreModelKey } from '@dereekb/firebase';\nimport { ModelKey, type Maybe } from '@dereekb/util';\nimport { DbxFirebaseDocumentStore } from './store.document';\nimport { BehaviorSubject, first, Observable, shareReplay, Subscription, switchMap } from 'rxjs';\nimport { filterMaybe, useFirst } from '@dereekb/rxjs';\nimport { DbxRouteModelIdDirectiveDelegate, DbxRouteModelKeyDirectiveDelegate, provideDbxRouteModelIdDirectiveDelegate, provideDbxRouteModelKeyDirectiveDelegate } from '@dereekb/dbx-core';\nimport { DbxFirebaseDocumentStoreTwoWayKeyProvider } from './store.document.twoway.key.source';\n\n/**\n * Abstract directive that contains a DbxFirebaseDocumentStore and provides an interface for communicating with other directives.\n */\n@Directive()\nexport abstract class DbxFirebaseDocumentStoreDirective<T = unknown, D extends FirestoreDocument<T> = FirestoreDocument<T>, S extends DbxFirebaseDocumentStore<T, D> = DbxFirebaseDocumentStore<T, D>> implements DbxFirebaseDocumentStoreTwoWayKeyProvider, DbxRouteModelIdDirectiveDelegate, DbxRouteModelKeyDirectiveDelegate, OnDestroy {\n  private readonly _store = new BehaviorSubject<Maybe<S>>(undefined);\n\n  readonly store$ = this._store.pipe(filterMaybe(), shareReplay(1));\n\n  readonly exists$ = this.store$.pipe(switchMap((x) => x.exists$));\n  readonly document$ = this.store$.pipe(switchMap((x) => x.document$));\n  readonly documentLoadingState$ = this.store$.pipe(switchMap((x) => x.documentLoadingState$));\n\n  readonly id$ = this.store$.pipe(switchMap((x) => x.id$));\n  readonly key$ = this.store$.pipe(switchMap((x) => x.key$));\n  readonly twoWayFlatKey$ = this.store$.pipe(switchMap((x) => x.twoWayFlatKey$));\n  readonly ref$ = this.store$.pipe(switchMap((x) => x.ref$));\n\n  readonly snapshot$ = this.store$.pipe(switchMap((x) => x.snapshot$));\n  readonly snapshotLoadingState$ = this.store$.pipe(switchMap((x) => x.snapshotLoadingState$));\n\n  readonly modelIdentity$ = this.store$.pipe(switchMap((x) => x.modelIdentity$));\n  readonly data$ = this.store$.pipe(switchMap((x) => x.data$));\n  readonly loadingState$ = this.store$.pipe(switchMap((x) => x.dataLoadingState$));\n\n  constructor(store: S) {\n    this.replaceStore(store);\n  }\n\n  ngOnDestroy(): void {\n    this._store.complete();\n  }\n\n  get store() {\n    return this._store.value as S;\n  }\n\n  /**\n   * Replaces the internal store.\n   */\n  replaceStore(store: S) {\n    this._store.next(store);\n  }\n\n  // MARK: DbxRouteModelIdDirectiveDelegate\n  useRouteModelIdParamsObservable(idFromParams: Observable<Maybe<ModelKey>>): Subscription {\n    return this.store$.pipe(first()).subscribe((x) => x.setId(idFromParams));\n  }\n\n  // MARK: DbxRouteModelKeyDirectiveDelegate\n  useRouteModelKeyParamsObservable(keyFromParams: Observable<Maybe<TwoWayFlatFirestoreModelKey>>): Subscription {\n    // we assume that the input model key is a TwoWayFlatFirestoreModelKey, since the TwoWayFlatFirestoreModelKey is safe to encode in the url\n    return this.store$.pipe(first()).subscribe((x) => x.setFlatKey(keyFromParams));\n  }\n\n  // MARK: Inputs\n  @Input()\n  set documentId(documentId: Maybe<FirestoreModelId>) {\n    useFirst(this.store$, (x) => x.setId(documentId));\n  }\n\n  @Input()\n  set key(key: Maybe<FirestoreModelKey>) {\n    useFirst(this.store$, (x) => x.setKey(key));\n  }\n\n  @Input()\n  set flatKey(flatKey: Maybe<TwoWayFlatFirestoreModelKey>) {\n    useFirst(this.store$, (x) => x.setFlatKey(flatKey));\n  }\n\n  @Input()\n  set ref(ref: Maybe<DocumentReference<T>>) {\n    useFirst(this.store$, (x) => x.setRef(ref));\n  }\n\n  @Input()\n  set streamMode(streamMode: FirestoreAccessorStreamMode) {\n    useFirst(this.store$, (x) => x.setStreamMode(streamMode));\n  }\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n// The use of any here does not degrade the type-safety; we want to simply match that the Store type S is used in the Directive type C to provide it.\n\n/**\n * Configures providers for a DbxFirebaseDocumentStoreDirective.\n *\n * Can optionally also provide the actual store type to include in the providers array so it is instantiated by Angular.\n *\n * @param sourceType\n */\nexport function provideDbxFirebaseDocumentStoreDirective<S extends DbxFirebaseDocumentStoreDirective<any, any, any>>(sourceType: Type<S>): Provider[];\nexport function provideDbxFirebaseDocumentStoreDirective<S extends DbxFirebaseDocumentStore<any, any>, C extends DbxFirebaseDocumentStoreDirective<any, any, S> = DbxFirebaseDocumentStoreDirective<any, any, S>>(sourceType: Type<C>, storeType: Type<S>): Provider[];\nexport function provideDbxFirebaseDocumentStoreDirective<S extends DbxFirebaseDocumentStore<any, any>, C extends DbxFirebaseDocumentStoreDirective<any, any, S> = DbxFirebaseDocumentStoreDirective<any, any, S>>(sourceType: Type<C>, storeType?: Type<S>): Provider[] {\n  const providers: Provider[] = [\n    {\n      provide: DbxFirebaseDocumentStoreDirective,\n      useExisting: forwardRef(() => sourceType)\n    },\n    ...provideDbxRouteModelIdDirectiveDelegate(sourceType),\n    ...provideDbxRouteModelKeyDirectiveDelegate(sourceType)\n  ];\n\n  if (storeType != null) {\n    providers.push(storeType);\n  }\n\n  return providers;\n}\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"store.document.directive.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-firebase/src/lib/model/modules/store/store.document.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, forwardRef, model, OnDestroy, Provider, Type } from '@angular/core';\nimport { DocumentReference, FirestoreAccessorStreamMode, FirestoreDocument, FirestoreModelKey, FirestoreModelId, TwoWayFlatFirestoreModelKey } from '@dereekb/firebase';\nimport { ModelKey, type Maybe } from '@dereekb/util';\nimport { DbxFirebaseDocumentStore } from './store.document';\nimport { BehaviorSubject, Observable, shareReplay, Subscription, switchMap } from 'rxjs';\nimport { filterMaybe, skipInitialMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { DbxRouteModelIdDirectiveDelegate, DbxRouteModelKeyDirectiveDelegate, provideDbxRouteModelIdDirectiveDelegate, provideDbxRouteModelKeyDirectiveDelegate } from '@dereekb/dbx-core';\nimport { DbxFirebaseDocumentStoreTwoWayKeyProvider } from './store.document.twoway.key.source';\nimport { toObservable } from '@angular/core/rxjs-interop';\n\n/**\n * Abstract directive that contains a DbxFirebaseDocumentStore and provides an interface for communicating with other directives.\n */\n@Directive()\nexport abstract class DbxFirebaseDocumentStoreDirective<T = unknown, D extends FirestoreDocument<T> = FirestoreDocument<T>, S extends DbxFirebaseDocumentStore<T, D> = DbxFirebaseDocumentStore<T, D>> implements DbxFirebaseDocumentStoreTwoWayKeyProvider, DbxRouteModelIdDirectiveDelegate, DbxRouteModelKeyDirectiveDelegate, OnDestroy {\n  readonly documentId = model<Maybe<FirestoreModelId>>(undefined);\n  readonly key = model<Maybe<FirestoreModelKey>>(undefined);\n  readonly flatKey = model<Maybe<TwoWayFlatFirestoreModelKey>>(undefined);\n  readonly ref = model<Maybe<DocumentReference<T>>>(undefined);\n  readonly streamMode = model<FirestoreAccessorStreamMode>(FirestoreAccessorStreamMode.STREAM);\n\n  private readonly _documentId$ = toObservable(this.documentId).pipe(skipInitialMaybe());\n  private readonly _key$ = toObservable(this.key).pipe(skipInitialMaybe());\n  private readonly _flatKey$ = toObservable(this.flatKey).pipe(skipInitialMaybe());\n  private readonly _ref$ = toObservable(this.ref).pipe(skipInitialMaybe());\n  private readonly _streamMode$ = toObservable(this.streamMode).pipe(skipInitialMaybe());\n\n  private readonly _store = new BehaviorSubject<Maybe<S>>(undefined);\n  private readonly _storeSub = new SubscriptionObject();\n\n  readonly store$ = this._store.pipe(filterMaybe(), shareReplay(1));\n\n  readonly exists$ = this.store$.pipe(switchMap((x) => x.exists$));\n  readonly document$ = this.store$.pipe(switchMap((x) => x.document$));\n  readonly documentLoadingState$ = this.store$.pipe(switchMap((x) => x.documentLoadingState$));\n\n  readonly id$ = this.store$.pipe(switchMap((x) => x.id$));\n  readonly key$ = this.store$.pipe(switchMap((x) => x.key$));\n  readonly twoWayFlatKey$ = this.store$.pipe(switchMap((x) => x.twoWayFlatKey$));\n  readonly ref$ = this.store$.pipe(switchMap((x) => x.ref$));\n\n  readonly snapshot$ = this.store$.pipe(switchMap((x) => x.snapshot$));\n  readonly snapshotLoadingState$ = this.store$.pipe(switchMap((x) => x.snapshotLoadingState$));\n\n  readonly modelIdentity$ = this.store$.pipe(switchMap((x) => x.modelIdentity$));\n  readonly data$ = this.store$.pipe(switchMap((x) => x.data$));\n  readonly loadingState$ = this.store$.pipe(switchMap((x) => x.dataLoadingState$));\n\n  constructor(store: S) {\n    this.replaceStore(store);\n\n    // sync inputs to store any time the store changes\n    this._storeSub.subscription = this._store.subscribe((x) => {\n      if (x) {\n        x.setId(this._documentId$);\n        x.setKey(this._key$);\n        x.setFlatKey(this._flatKey$);\n        x.setRef(this._ref$);\n        x.setStreamMode(this._streamMode$);\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._store.complete();\n    this._storeSub.destroy();\n  }\n\n  get store() {\n    return this._store.value as S;\n  }\n\n  // MARK: Setters\n  setDocumentId(documentId: Maybe<FirestoreModelId>) {\n    this.documentId.set(documentId);\n  }\n\n  setKey(key: Maybe<FirestoreModelKey>) {\n    this.key.set(key);\n  }\n\n  setFlatKey(flatKey: Maybe<TwoWayFlatFirestoreModelKey>) {\n    this.flatKey.set(flatKey);\n  }\n\n  setRef(ref: Maybe<DocumentReference<T>>) {\n    this.ref.set(ref);\n  }\n\n  setStreamMode(streamMode: FirestoreAccessorStreamMode) {\n    this.streamMode.set(streamMode);\n  }\n\n  /**\n   * Replaces the internal store.\n   */\n  replaceStore(store: S) {\n    this._store.next(store);\n  }\n\n  // MARK: DbxRouteModelIdDirectiveDelegate\n  useRouteModelIdParamsObservable(idFromParams: Observable<Maybe<ModelKey>>): Subscription {\n    return idFromParams.subscribe((x) => this.setDocumentId(x));\n  }\n\n  // MARK: DbxRouteModelKeyDirectiveDelegate\n  useRouteModelKeyParamsObservable(keyFromParams: Observable<Maybe<TwoWayFlatFirestoreModelKey>>): Subscription {\n    // we assume that the input model key is a TwoWayFlatFirestoreModelKey, since the TwoWayFlatFirestoreModelKey is safe to encode in the url\n    return keyFromParams.subscribe((x) => this.setFlatKey(x));\n  }\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n// The use of any here does not degrade the type-safety; we want to simply match that the Store type S is used in the Directive type C to provide it.\n\n/**\n * Configures providers for a DbxFirebaseDocumentStoreDirective.\n *\n * Can optionally also provide the actual store type to include in the providers array so it is instantiated by Angular.\n *\n * @param sourceType\n */\nexport function provideDbxFirebaseDocumentStoreDirective<S extends DbxFirebaseDocumentStoreDirective<any, any, any>>(sourceType: Type<S>): Provider[];\nexport function provideDbxFirebaseDocumentStoreDirective<S extends DbxFirebaseDocumentStore<any, any>, C extends DbxFirebaseDocumentStoreDirective<any, any, S> = DbxFirebaseDocumentStoreDirective<any, any, S>>(sourceType: Type<C>, storeType: Type<S>): Provider[];\nexport function provideDbxFirebaseDocumentStoreDirective<S extends DbxFirebaseDocumentStore<any, any>, C extends DbxFirebaseDocumentStoreDirective<any, any, S> = DbxFirebaseDocumentStoreDirective<any, any, S>>(sourceType: Type<C>, storeType?: Type<S>): Provider[] {\n  const providers: Provider[] = [\n    {\n      provide: DbxFirebaseDocumentStoreDirective,\n      useExisting: forwardRef(() => sourceType)\n    },\n    ...provideDbxRouteModelIdDirectiveDelegate(sourceType),\n    ...provideDbxRouteModelKeyDirectiveDelegate(sourceType)\n  ];\n\n  if (storeType != null) {\n    providers.push(storeType);\n  }\n\n  return providers;\n}\n"]}
|
|
@@ -1,22 +1,36 @@
|
|
|
1
|
-
import { Directive, forwardRef,
|
|
1
|
+
import { Directive, forwardRef, model } from '@angular/core';
|
|
2
2
|
import { DbxFirebaseCollectionStoreDirective, provideDbxFirebaseCollectionStoreDirective } from './store.collection.directive';
|
|
3
|
+
import { toObservable } from '@angular/core/rxjs-interop';
|
|
4
|
+
import { skipInitialMaybe, SubscriptionObject } from '@dereekb/rxjs';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
/**
|
|
5
7
|
* Abstract directive that contains a DbxFirebaseCollectionWithParentStore and provides an interface for communicating with other directives.
|
|
6
8
|
*/
|
|
7
9
|
export class DbxFirebaseCollectionWithParentStoreDirective extends DbxFirebaseCollectionStoreDirective {
|
|
10
|
+
sourceMode = model(undefined);
|
|
11
|
+
_sourceMode$ = toObservable(this.sourceMode).pipe(skipInitialMaybe());
|
|
12
|
+
_parentSourceModeSub = new SubscriptionObject();
|
|
13
|
+
constructor(store) {
|
|
14
|
+
super(store);
|
|
15
|
+
// sync inputs to store any time the store changes
|
|
16
|
+
this._parentSourceModeSub.subscription = this.store$.subscribe((x) => {
|
|
17
|
+
x.setSourceMode(this._sourceMode$);
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
ngOnDestroy() {
|
|
21
|
+
super.ngOnDestroy();
|
|
22
|
+
this._parentSourceModeSub.destroy();
|
|
23
|
+
}
|
|
8
24
|
// MARK: Inputs
|
|
9
|
-
|
|
10
|
-
this.
|
|
25
|
+
setSourceMode(sourceMode) {
|
|
26
|
+
this.sourceMode.set(sourceMode);
|
|
11
27
|
}
|
|
12
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseCollectionWithParentStoreDirective, deps:
|
|
13
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
28
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseCollectionWithParentStoreDirective, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
|
|
29
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFirebaseCollectionWithParentStoreDirective, inputs: { sourceMode: { classPropertyName: "sourceMode", publicName: "sourceMode", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { sourceMode: "sourceModeChange" }, usesInheritance: true, ngImport: i0 });
|
|
14
30
|
}
|
|
15
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFirebaseCollectionWithParentStoreDirective, decorators: [{
|
|
16
32
|
type: Directive
|
|
17
|
-
}],
|
|
18
|
-
type: Input
|
|
19
|
-
}] } });
|
|
33
|
+
}], ctorParameters: () => [{ type: undefined }] });
|
|
20
34
|
export function provideDbxFirebaseCollectionWithParentStoreDirective(sourceType, storeType) {
|
|
21
35
|
const providers = [
|
|
22
36
|
...provideDbxFirebaseCollectionStoreDirective(sourceType, storeType),
|
|
@@ -27,4 +41,4 @@ export function provideDbxFirebaseCollectionWithParentStoreDirective(sourceType,
|
|
|
27
41
|
];
|
|
28
42
|
return providers;
|
|
29
43
|
}
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmUuc3ViY29sbGVjdGlvbi5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZmlyZWJhc2Uvc3JjL2xpYi9tb2RlbC9tb2R1bGVzL3N0b3JlL3N0b3JlLnN1YmNvbGxlY3Rpb24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBNkIsTUFBTSxlQUFlLENBQUM7QUFHeEYsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLDBDQUEwQyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFL0gsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFckU7O0dBRUc7QUFFSCxNQUFNLE9BQWdCLDZDQUF5UixTQUFRLG1DQUE0QztJQUN4VixVQUFVLEdBQUcsS0FBSyxDQUF1RCxTQUFTLENBQUMsQ0FBQztJQUU1RSxZQUFZLEdBQUcsWUFBWSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO0lBRXRFLG9CQUFvQixHQUFHLElBQUksa0JBQWtCLEVBQUUsQ0FBQztJQUVqRSxZQUFZLEtBQVE7UUFDbEIsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWIsa0RBQWtEO1FBQ2xELElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUNuRSxDQUFDLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNyQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFUSxXQUFXO1FBQ2xCLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNwQixJQUFJLENBQUMsb0JBQW9CLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDdEMsQ0FBQztJQUVELGVBQWU7SUFDZixhQUFhLENBQUMsVUFBZ0U7UUFDNUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDbEMsQ0FBQzt3R0F4Qm1CLDZDQUE2Qzs0RkFBN0MsNkNBQTZDOzs0RkFBN0MsNkNBQTZDO2tCQURsRSxTQUFTOztBQXdDVixNQUFNLFVBQVUsb0RBQW9ELENBQTROLFVBQW1CLEVBQUUsU0FBbUI7SUFDdFUsTUFBTSxTQUFTLEdBQWU7UUFDNUIsR0FBRywwQ0FBMEMsQ0FBQyxVQUFVLEVBQUUsU0FBUyxDQUFDO1FBQ3BFO1lBQ0UsT0FBTyxFQUFFLDZDQUE2QztZQUN0RCxXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLFVBQVUsQ0FBQztTQUMxQztLQUNGLENBQUM7SUFFRixPQUFPLFNBQVMsQ0FBQztBQUNuQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBmb3J3YXJkUmVmLCBtb2RlbCwgUHJvdmlkZXIsIFR5cGUsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmlyZXN0b3JlRG9jdW1lbnQgfSBmcm9tICdAZGVyZWVrYi9maXJlYmFzZSc7XG5pbXBvcnQgeyB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBEYnhGaXJlYmFzZUNvbGxlY3Rpb25TdG9yZURpcmVjdGl2ZSwgcHJvdmlkZURieEZpcmViYXNlQ29sbGVjdGlvblN0b3JlRGlyZWN0aXZlIH0gZnJvbSAnLi9zdG9yZS5jb2xsZWN0aW9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmUsIERieEZpcmViYXNlQ29tcG9uZW50U3RvcmVXaXRoUGFyZW50U291cmNlTW9kZSB9IGZyb20gJy4vc3RvcmUuc3ViY29sbGVjdGlvbic7XG5pbXBvcnQgeyB0b09ic2VydmFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBza2lwSW5pdGlhbE1heWJlLCBTdWJzY3JpcHRpb25PYmplY3QgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcblxuLyoqXG4gKiBBYnN0cmFjdCBkaXJlY3RpdmUgdGhhdCBjb250YWlucyBhIERieEZpcmViYXNlQ29sbGVjdGlvbldpdGhQYXJlbnRTdG9yZSBhbmQgcHJvdmlkZXMgYW4gaW50ZXJmYWNlIGZvciBjb21tdW5pY2F0aW5nIHdpdGggb3RoZXIgZGlyZWN0aXZlcy5cbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgRGJ4RmlyZWJhc2VDb2xsZWN0aW9uV2l0aFBhcmVudFN0b3JlRGlyZWN0aXZlPFQsIFBULCBEIGV4dGVuZHMgRmlyZXN0b3JlRG9jdW1lbnQ8VD4gPSBGaXJlc3RvcmVEb2N1bWVudDxUPiwgUEQgZXh0ZW5kcyBGaXJlc3RvcmVEb2N1bWVudDxQVD4gPSBGaXJlc3RvcmVEb2N1bWVudDxQVD4sIFMgZXh0ZW5kcyBEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmU8VCwgUFQsIEQsIFBEPiA9IERieEZpcmViYXNlQ29sbGVjdGlvbldpdGhQYXJlbnRTdG9yZTxULCBQVCwgRCwgUEQ+PiBleHRlbmRzIERieEZpcmViYXNlQ29sbGVjdGlvblN0b3JlRGlyZWN0aXZlPFQsIEQsIFM+IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcmVhZG9ubHkgc291cmNlTW9kZSA9IG1vZGVsPE1heWJlPERieEZpcmViYXNlQ29tcG9uZW50U3RvcmVXaXRoUGFyZW50U291cmNlTW9kZT4+KHVuZGVmaW5lZCk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfc291cmNlTW9kZSQgPSB0b09ic2VydmFibGUodGhpcy5zb3VyY2VNb2RlKS5waXBlKHNraXBJbml0aWFsTWF5YmUoKSk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfcGFyZW50U291cmNlTW9kZVN1YiA9IG5ldyBTdWJzY3JpcHRpb25PYmplY3QoKTtcblxuICBjb25zdHJ1Y3RvcihzdG9yZTogUykge1xuICAgIHN1cGVyKHN0b3JlKTtcblxuICAgIC8vIHN5bmMgaW5wdXRzIHRvIHN0b3JlIGFueSB0aW1lIHRoZSBzdG9yZSBjaGFuZ2VzXG4gICAgdGhpcy5fcGFyZW50U291cmNlTW9kZVN1Yi5zdWJzY3JpcHRpb24gPSB0aGlzLnN0b3JlJC5zdWJzY3JpYmUoKHgpID0+IHtcbiAgICAgIHguc2V0U291cmNlTW9kZSh0aGlzLl9zb3VyY2VNb2RlJCk7XG4gICAgfSk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICBzdXBlci5uZ09uRGVzdHJveSgpO1xuICAgIHRoaXMuX3BhcmVudFNvdXJjZU1vZGVTdWIuZGVzdHJveSgpO1xuICB9XG5cbiAgLy8gTUFSSzogSW5wdXRzXG4gIHNldFNvdXJjZU1vZGUoc291cmNlTW9kZTogTWF5YmU8RGJ4RmlyZWJhc2VDb21wb25lbnRTdG9yZVdpdGhQYXJlbnRTb3VyY2VNb2RlPikge1xuICAgIHRoaXMuc291cmNlTW9kZS5zZXQoc291cmNlTW9kZSk7XG4gIH1cbn1cblxuLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuLy8gVGhlIHVzZSBvZiBhbnkgaGVyZSBkb2VzIG5vdCBkZWdyYWRlIHRoZSB0eXBlLXNhZmV0eTsgd2Ugd2FudCB0byBzaW1wbHkgbWF0Y2ggdGhhdCB0aGUgU3RvcmUgdHlwZSBTIGlzIHVzZWQgaW4gdGhlIERpcmVjdGl2ZSB0eXBlIEMgdG8gcHJvdmlkZSBpdC5cblxuLyoqXG4gKiBDb25maWd1cmVzIHByb3ZpZGVycyBmb3IgYSBEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmVEaXJlY3RpdmUuXG4gKlxuICogQ2FuIG9wdGlvbmFsbHkgYWxzbyBwcm92aWRlIHRoZSBhY3R1YWwgc3RvcmUgdHlwZSB0byBpbmNsdWRlIGluIHRoZSBwcm92aWRlcnMgYXJyYXkgc28gaXQgaXMgaW5zdGFudGlhdGVkIGJ5IEFuZ3VsYXIuXG4gKlxuICogQHBhcmFtIHNvdXJjZVR5cGVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmVEaXJlY3RpdmU8UyBleHRlbmRzIERieEZpcmViYXNlQ29sbGVjdGlvbldpdGhQYXJlbnRTdG9yZURpcmVjdGl2ZTxhbnksIGFueSwgYW55LCBhbnksIGFueT4+KHNvdXJjZVR5cGU6IFR5cGU8Uz4pOiBQcm92aWRlcltdO1xuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmVEaXJlY3RpdmU8UyBleHRlbmRzIERieEZpcmViYXNlQ29sbGVjdGlvbldpdGhQYXJlbnRTdG9yZTxhbnksIGFueSwgYW55LCBhbnk+LCBDIGV4dGVuZHMgRGJ4RmlyZWJhc2VDb2xsZWN0aW9uV2l0aFBhcmVudFN0b3JlRGlyZWN0aXZlPGFueSwgYW55LCBhbnksIGFueSwgUz4gPSBEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmVEaXJlY3RpdmU8YW55LCBhbnksIGFueSwgYW55LCBTPj4oc291cmNlVHlwZTogVHlwZTxDPiwgc3RvcmVUeXBlPzogVHlwZTxTPik6IFByb3ZpZGVyW107XG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZURieEZpcmViYXNlQ29sbGVjdGlvbldpdGhQYXJlbnRTdG9yZURpcmVjdGl2ZTxTIGV4dGVuZHMgRGJ4RmlyZWJhc2VDb2xsZWN0aW9uV2l0aFBhcmVudFN0b3JlPGFueSwgYW55LCBhbnksIGFueT4sIEMgZXh0ZW5kcyBEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmVEaXJlY3RpdmU8YW55LCBhbnksIGFueSwgYW55LCBTPiA9IERieEZpcmViYXNlQ29sbGVjdGlvbldpdGhQYXJlbnRTdG9yZURpcmVjdGl2ZTxhbnksIGFueSwgYW55LCBhbnksIFM+Pihzb3VyY2VUeXBlOiBUeXBlPEM+LCBzdG9yZVR5cGU/OiBUeXBlPFM+KTogUHJvdmlkZXJbXSB7XG4gIGNvbnN0IHByb3ZpZGVyczogUHJvdmlkZXJbXSA9IFtcbiAgICAuLi5wcm92aWRlRGJ4RmlyZWJhc2VDb2xsZWN0aW9uU3RvcmVEaXJlY3RpdmUoc291cmNlVHlwZSwgc3RvcmVUeXBlKSxcbiAgICB7XG4gICAgICBwcm92aWRlOiBEYnhGaXJlYmFzZUNvbGxlY3Rpb25XaXRoUGFyZW50U3RvcmVEaXJlY3RpdmUsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBzb3VyY2VUeXBlKVxuICAgIH1cbiAgXTtcblxuICByZXR1cm4gcHJvdmlkZXJzO1xufVxuIl19
|