@dereekb/dbx-firebase 12.6.16 → 12.6.18
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/model/modules/model/entities/model.entities.component.mjs +62 -19
- package/esm2022/lib/model/modules/model/entities/model.entities.entity.component.mjs +5 -3
- package/esm2022/lib/model/modules/model/entities/model.entities.popover.component.mjs +12 -7
- package/esm2022/lib/model/modules/model/entities/model.entities.widget.entity.abstract.directive.mjs +5 -5
- package/esm2022/lib/model/modules/model/entities/model.entities.widget.entity.debug.component.mjs +5 -5
- package/esm2022/lib/model/modules/model/entities/model.entities.widget.mjs +1 -1
- package/fesm2022/dereekb-dbx-firebase.mjs +80 -30
- package/fesm2022/dereekb-dbx-firebase.mjs.map +1 -1
- package/lib/model/modules/model/_model.scss +6 -0
- package/lib/model/modules/model/entities/model.entities.component.d.ts +28 -5
- package/lib/model/modules/model/entities/model.entities.entity.component.d.ts +4 -0
- package/lib/model/modules/model/entities/model.entities.popover.component.d.ts +17 -3
- package/lib/model/modules/model/entities/model.entities.widget.d.ts +1 -1
- package/lib/model/modules/model/entities/model.entities.widget.entity.abstract.directive.d.ts +7 -6
- package/lib/model/modules/model/entities/model.entities.widget.entity.debug.component.d.ts +2 -2
- package/package.json +1 -1
|
@@ -1,7 +1,13 @@
|
|
|
1
1
|
@use '../../../style/theming';
|
|
2
2
|
|
|
3
|
+
$dbx-firebase-model-entities-expansion-panel-height: 64px;
|
|
4
|
+
|
|
3
5
|
// MARK: Mixin
|
|
4
6
|
@mixin core() {
|
|
7
|
+
.dbx-firebase-model-entities-accordion {
|
|
8
|
+
--mat-expansion-header-collapsed-state-height: #{$dbx-firebase-model-entities-expansion-panel-height};
|
|
9
|
+
--mat-expansion-header-expanded-state-height: #{$dbx-firebase-model-entities-expansion-panel-height};
|
|
10
|
+
}
|
|
5
11
|
}
|
|
6
12
|
|
|
7
13
|
@mixin color($theme-config) {
|
|
@@ -5,20 +5,43 @@ import { Maybe } from '@dereekb/util';
|
|
|
5
5
|
import { LoadingState } from '@dereekb/rxjs';
|
|
6
6
|
import { DbxFirebaseModelEntitiesWidgetService } from './model.entities.widget.service';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
|
+
interface DbxFirebaseModelEntitiesComponentAllEntities {
|
|
9
|
+
readonly entities: DbxFirebaseModelEntityWithKeyAndStore[];
|
|
10
|
+
readonly registeredEntities: DbxFirebaseModelEntityWithKeyAndStore[];
|
|
11
|
+
readonly unregisteredEntities: DbxFirebaseModelEntityWithKeyAndStore[];
|
|
12
|
+
readonly onlyShowRegisteredTypes?: Maybe<boolean>;
|
|
13
|
+
}
|
|
8
14
|
export declare class DbxFirebaseModelEntitiesComponent implements OnDestroy {
|
|
9
15
|
readonly entitiesWidgetService: DbxFirebaseModelEntitiesWidgetService;
|
|
10
16
|
/**
|
|
11
17
|
* Whether the accordion should allow multiple expanded panels.
|
|
12
18
|
*/
|
|
13
19
|
readonly multi: import("@angular/core").InputSignal<boolean>;
|
|
20
|
+
/**
|
|
21
|
+
* If true, will only show entities that have a registered widget entry.
|
|
22
|
+
*
|
|
23
|
+
* Defaults to true.
|
|
24
|
+
*/
|
|
25
|
+
readonly onlyShowRegisteredTypes: import("@angular/core").InputSignal<Maybe<boolean>>;
|
|
26
|
+
/**
|
|
27
|
+
* If true, will show unregistered entities, even if onlyShowRegisteredTypes is true.
|
|
28
|
+
*/
|
|
29
|
+
readonly showUnregisteredTypesSignal: import("@angular/core").WritableSignal<Maybe<boolean>>;
|
|
30
|
+
readonly onlyShowRegisteredTypesSignal: import("@angular/core").Signal<Maybe<boolean>>;
|
|
31
|
+
readonly onlyShowRegisteredTypes$: Observable<Maybe<boolean>>;
|
|
14
32
|
readonly entities: import("@angular/core").InputSignal<Observable<LoadingState<DbxFirebaseModelEntity[]>> | undefined>;
|
|
15
33
|
readonly entities$: Observable<LoadingState<DbxFirebaseModelEntity[]>>;
|
|
16
|
-
readonly
|
|
17
|
-
readonly
|
|
18
|
-
readonly
|
|
34
|
+
readonly allEntitiesState$: Observable<LoadingState<DbxFirebaseModelEntitiesComponentAllEntities>>;
|
|
35
|
+
readonly allEntities$: Observable<Maybe<DbxFirebaseModelEntitiesComponentAllEntities>>;
|
|
36
|
+
readonly allEntitiesSignal: import("@angular/core").Signal<Maybe<DbxFirebaseModelEntitiesComponentAllEntities>>;
|
|
37
|
+
readonly entitiesWithKeysSignal: import("@angular/core").Signal<DbxFirebaseModelEntityWithKeyAndStore<any, import("dist/packages/firebase/src").FirestoreDocument<any, import("dist/packages/firebase/src").FirestoreModelIdentity>>[] | undefined>;
|
|
38
|
+
readonly unregisteredEntitiesCountSignal: import("@angular/core").Signal<number>;
|
|
39
|
+
readonly showViewUnregisteredEntitiesButtonSignal: import("@angular/core").Signal<boolean | import("@dereekb/util").MaybeNot>;
|
|
19
40
|
readonly hasNoEntitiesSignal: import("@angular/core").Signal<boolean>;
|
|
20
|
-
readonly context: import("@dereekb/rxjs").MutableLoadingStateContext<unknown, LoadingState<
|
|
41
|
+
readonly context: import("@dereekb/rxjs").MutableLoadingStateContext<unknown, LoadingState<DbxFirebaseModelEntitiesComponentAllEntities>, import("@dereekb/rxjs").LoadingContextEvent & LoadingState<DbxFirebaseModelEntitiesComponentAllEntities>>;
|
|
21
42
|
ngOnDestroy(): void;
|
|
43
|
+
clickShowUnregisteredEntities(): void;
|
|
22
44
|
static ɵfac: i0.ɵɵFactoryDeclaration<DbxFirebaseModelEntitiesComponent, never>;
|
|
23
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DbxFirebaseModelEntitiesComponent, "dbx-firebase-model-entities", never, { "multi": { "alias": "multi"; "required": false; "isSignal": true; }; "entities": { "alias": "entities"; "required": false; "isSignal": true; }; }, {}, never, ["[empty]"], true, never>;
|
|
45
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DbxFirebaseModelEntitiesComponent, "dbx-firebase-model-entities", never, { "multi": { "alias": "multi"; "required": false; "isSignal": true; }; "onlyShowRegisteredTypes": { "alias": "onlyShowRegisteredTypes"; "required": false; "isSignal": true; }; "entities": { "alias": "entities"; "required": false; "isSignal": true; }; }, {}, never, ["[empty]"], true, never>;
|
|
24
46
|
}
|
|
47
|
+
export {};
|
|
@@ -25,6 +25,10 @@ export declare class DbxFirebaseModelEntitiesEntityComponent implements OnDestro
|
|
|
25
25
|
readonly widgetInjectionConfig$: Observable<import("./model.entities.widget").DbxFirebaseModelEntitiesWidgetInjectionConfig | null>;
|
|
26
26
|
readonly hasTypeInfoSignal: import("@angular/core").Signal<boolean | undefined>;
|
|
27
27
|
readonly displayInfoSignal: import("@angular/core").Signal<import("@dereekb/dbx-core").IconAndTitle | undefined>;
|
|
28
|
+
readonly modelIdentitySignal: import("@angular/core").Signal<(import("dist/packages/firebase/src").FirestoreModelTypeRef<string> & import("dist/packages/firebase/src").FirestoreCollectionNameRef<string> & import("dist/packages/firebase/src").FirestoreCollectionTypeRef & {
|
|
29
|
+
readonly type: import("dist/packages/firebase/src").FirestoreModelIdentityType;
|
|
30
|
+
}) | undefined>;
|
|
31
|
+
readonly modelTypeSignal: import("@angular/core").Signal<string | undefined>;
|
|
28
32
|
readonly widgetInjectionConfigSignal: import("@angular/core").Signal<import("./model.entities.widget").DbxFirebaseModelEntitiesWidgetInjectionConfig | null | undefined>;
|
|
29
33
|
readonly entityWidgetConfigSignal: import("@angular/core").Signal<Maybe<import("@dereekb/dbx-core").DbxInjectionComponentConfig<unknown>>>;
|
|
30
34
|
readonly commonWidgetConfigSignal: import("@angular/core").Signal<Maybe<import("@dereekb/dbx-core").DbxInjectionComponentConfig<unknown>>>;
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { ElementRef } from '@angular/core';
|
|
1
|
+
import { ElementRef, Injector } from '@angular/core';
|
|
2
2
|
import { NgPopoverRef } from 'ng-overlay-container';
|
|
3
|
-
import { AbstractPopoverDirective, DbxPopoverKey, DbxPopoverService } from '@dereekb/dbx-web';
|
|
3
|
+
import { AbstractPopoverDirective, DbxPopoverConfigSizing, DbxPopoverKey, DbxPopoverService } from '@dereekb/dbx-web';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
5
|
import { LoadingState } from '@dereekb/rxjs';
|
|
6
6
|
import { DbxFirebaseModelEntity } from './model.entities';
|
|
7
|
+
import { Maybe } from '@dereekb/util';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
export interface DbxFirebaseModelEntitiesPopoverConfig {
|
|
9
10
|
/**
|
|
@@ -30,16 +31,29 @@ export interface DbxFirebaseModelEntitiesPopoverConfig {
|
|
|
30
31
|
* Observable of entities to display.
|
|
31
32
|
*/
|
|
32
33
|
readonly entities$: Observable<LoadingState<DbxFirebaseModelEntity[]>>;
|
|
34
|
+
/**
|
|
35
|
+
* Whether or not to only show entities that have a registered widget entry.
|
|
36
|
+
*/
|
|
37
|
+
readonly onlyShowRegisteredTypes?: Maybe<boolean>;
|
|
38
|
+
/**
|
|
39
|
+
* Additional popover configuration.
|
|
40
|
+
*/
|
|
41
|
+
readonly popoverSizingConfig?: Maybe<DbxPopoverConfigSizing>;
|
|
42
|
+
/**
|
|
43
|
+
* Injector to use for the popover.
|
|
44
|
+
*/
|
|
45
|
+
readonly injector?: Maybe<Injector>;
|
|
33
46
|
}
|
|
34
47
|
export type DbxFirebaseModelEntitiesPopoverConfigWithoutOrigin = Omit<DbxFirebaseModelEntitiesPopoverConfig, 'origin' | 'entities$'>;
|
|
35
48
|
export declare const DEFAULT_DBX_FIREBASE_MODEL_ENTITIES_COMPONENT_POPOVER_KEY = "entities";
|
|
36
49
|
export declare class DbxFirebaseModelEntitiesPopoverComponent extends AbstractPopoverDirective<unknown, DbxFirebaseModelEntitiesPopoverConfig> {
|
|
37
50
|
readonly entities$: Observable<LoadingState<DbxFirebaseModelEntity[]>> | undefined;
|
|
38
|
-
static openPopover(popupService: DbxPopoverService,
|
|
51
|
+
static openPopover(popupService: DbxPopoverService, config: DbxFirebaseModelEntitiesPopoverConfig, popoverKey?: DbxPopoverKey): NgPopoverRef;
|
|
39
52
|
get config(): DbxFirebaseModelEntitiesPopoverConfig;
|
|
40
53
|
readonly icon: string;
|
|
41
54
|
readonly header: string;
|
|
42
55
|
readonly emptyText: string;
|
|
56
|
+
readonly onlyShowRegisteredTypes: Maybe<boolean>;
|
|
43
57
|
static ɵfac: i0.ɵɵFactoryDeclaration<DbxFirebaseModelEntitiesPopoverComponent, never>;
|
|
44
58
|
static ɵcmp: i0.ɵɵComponentDeclaration<DbxFirebaseModelEntitiesPopoverComponent, "ng-component", never, {}, {}, never, never, true, never>;
|
|
45
59
|
}
|
|
@@ -6,7 +6,7 @@ import { type Maybe } from '@dereekb/util';
|
|
|
6
6
|
/**
|
|
7
7
|
* Injection token for providing DbxFirebaseModelEntityWithStore context to dynamically loaded widgets.
|
|
8
8
|
*/
|
|
9
|
-
export declare const DBX_FIREBASE_MODEL_ENTITY_WITH_STORE_TOKEN: InjectionToken<DbxFirebaseModelEntityWithStore<any,
|
|
9
|
+
export declare const DBX_FIREBASE_MODEL_ENTITY_WITH_STORE_TOKEN: InjectionToken<DbxFirebaseModelEntityWithStore<any, any>>;
|
|
10
10
|
/**
|
|
11
11
|
* Contains the DbxInjectionComponentConfig for the different injected components a DbxFirebaseModelEntity
|
|
12
12
|
*/
|
package/lib/model/modules/model/entities/model.entities.widget.entity.abstract.directive.d.ts
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { DbxFirebaseModelEntityWithStore } from './model.entities';
|
|
2
|
+
import { type FirestoreDocument } from '@dereekb/firebase';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
/**
|
|
4
5
|
* An abstract DbxFirebase widget component that injects the entity data and provides some common accessors.
|
|
5
6
|
*/
|
|
6
|
-
export declare abstract class
|
|
7
|
-
readonly entityData: DbxFirebaseModelEntityWithStore
|
|
8
|
-
readonly store: import("@dereekb/dbx-firebase").DbxFirebaseDocumentReadOnlyStore<
|
|
9
|
-
readonly data$: import("rxjs").Observable<
|
|
10
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<
|
|
11
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<
|
|
7
|
+
export declare abstract class AbstractDbxFirebaseModelEntityWidgetDirective<T = any, D extends FirestoreDocument<T> = FirestoreDocument<T>> {
|
|
8
|
+
readonly entityData: DbxFirebaseModelEntityWithStore<T, D>;
|
|
9
|
+
readonly store: import("@dereekb/dbx-firebase").DbxFirebaseDocumentReadOnlyStore<T, D>;
|
|
10
|
+
readonly data$: import("rxjs").Observable<import("@dereekb/firebase").DocumentDataWithIdAndKey<T>>;
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AbstractDbxFirebaseModelEntityWidgetDirective<any, any>, never>;
|
|
12
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<AbstractDbxFirebaseModelEntityWidgetDirective<any, any>, never, never, {}, {}, never, never, false, never>;
|
|
12
13
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { OnDestroy, Signal } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { AbstractDbxFirebaseModelEntityWidgetDirective } from './model.entities.widget.entity.abstract.directive';
|
|
3
3
|
import { DownloadTextContent } from '@dereekb/dbx-web';
|
|
4
4
|
import { Maybe } from '@dereekb/util';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
/**
|
|
7
7
|
* A debug widget component that displays entity data and metadata.
|
|
8
8
|
*/
|
|
9
|
-
export declare class DbxFirebaseModelEntitiesDebugWidgetComponent extends
|
|
9
|
+
export declare class DbxFirebaseModelEntitiesDebugWidgetComponent extends AbstractDbxFirebaseModelEntityWidgetDirective implements OnDestroy {
|
|
10
10
|
readonly currentKey: Signal<Maybe<string>>;
|
|
11
11
|
readonly currentData: Signal<any>;
|
|
12
12
|
readonly contentSignal: Signal<Maybe<DownloadTextContent>>;
|