@dereekb/dbx-web 9.24.0 → 9.24.2
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/calendar/package.json +2 -2
- package/esm2020/lib/interaction/dialog/dialog.content.footer.component.mjs +13 -4
- package/esm2020/lib/layout/list/list.component.mjs +2 -2
- package/esm2020/lib/loading/loading.component.mjs +9 -5
- package/esm2020/table/lib/table.component.mjs +1 -1
- package/fesm2015/dereekb-dbx-web-table.mjs +1 -1
- package/fesm2015/dereekb-dbx-web-table.mjs.map +1 -1
- package/fesm2015/dereekb-dbx-web.mjs +20 -6
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web-table.mjs +1 -1
- package/fesm2020/dereekb-dbx-web-table.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +19 -6
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/interaction/dialog/dialog.content.footer.component.d.ts +9 -1
- package/lib/loading/_loading.scss +34 -0
- package/lib/loading/loading.component.d.ts +5 -1
- package/lib/router/layout/anchorlist/_anchorlist.scss +2 -2
- package/lib/style/_all-core.scss +2 -0
- package/lib/style/_all-theme.scss +2 -0
- package/lib/style/_all-typography.scss +2 -0
- package/mapbox/package.json +3 -3
- package/package.json +3 -3
- package/table/esm2020/lib/table.component.mjs +1 -1
- package/table/fesm2015/dereekb-dbx-web-table.mjs +1 -1
- package/table/fesm2015/dereekb-dbx-web-table.mjs.map +1 -1
- package/table/fesm2020/dereekb-dbx-web-table.mjs +1 -1
- package/table/fesm2020/dereekb-dbx-web-table.mjs.map +1 -1
- package/table/package.json +3 -3
package/calendar/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/dbx-web/calendar",
|
|
3
|
-
"version": "9.24.
|
|
3
|
+
"version": "9.24.2",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^14.2.0",
|
|
6
6
|
"@angular/core": "^14.2.0",
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
"rxjs": "^7.5.0",
|
|
9
9
|
"@angular/material": "^14.2.0",
|
|
10
10
|
"angular-calendar": "^0.30.1",
|
|
11
|
-
"@dereekb/dbx-web": "9.24.
|
|
11
|
+
"@dereekb/dbx-web": "9.24.2"
|
|
12
12
|
},
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"tslib": "^2.3.0"
|
|
@@ -7,8 +7,13 @@ import * as i1 from "@angular/material/button";
|
|
|
7
7
|
export class DbxDialogContentFooterComponent {
|
|
8
8
|
constructor() {
|
|
9
9
|
this.closeText = 'Close';
|
|
10
|
+
this.buttonColor = undefined;
|
|
10
11
|
this.close = new EventEmitter();
|
|
11
12
|
}
|
|
13
|
+
set config(config) {
|
|
14
|
+
this.closeText = config?.closeText ?? 'Close';
|
|
15
|
+
this.buttonColor = config?.buttonColor ?? undefined;
|
|
16
|
+
}
|
|
12
17
|
closeClicked() {
|
|
13
18
|
this.close.emit(undefined);
|
|
14
19
|
}
|
|
@@ -17,15 +22,15 @@ export class DbxDialogContentFooterComponent {
|
|
|
17
22
|
}
|
|
18
23
|
}
|
|
19
24
|
DbxDialogContentFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxDialogContentFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
20
|
-
DbxDialogContentFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxDialogContentFooterComponent, selector: "dbx-dialog-content-footer", inputs: { closeText: "closeText" }, outputs: { close: "close" }, host: { classAttribute: "dbx-dialog-content-footer" }, ngImport: i0, template: `
|
|
21
|
-
<button mat-raised-button (click)="closeClicked()">{{ closeText }}</button>
|
|
25
|
+
DbxDialogContentFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxDialogContentFooterComponent, selector: "dbx-dialog-content-footer", inputs: { closeText: "closeText", buttonColor: "buttonColor", config: "config" }, outputs: { close: "close" }, host: { classAttribute: "dbx-dialog-content-footer" }, ngImport: i0, template: `
|
|
26
|
+
<button mat-raised-button [color]="buttonColor" (click)="closeClicked()">{{ closeText }}</button>
|
|
22
27
|
`, isInline: true, dependencies: [{ kind: "component", type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] });
|
|
23
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxDialogContentFooterComponent, decorators: [{
|
|
24
29
|
type: Component,
|
|
25
30
|
args: [{
|
|
26
31
|
selector: 'dbx-dialog-content-footer',
|
|
27
32
|
template: `
|
|
28
|
-
<button mat-raised-button (click)="closeClicked()">{{ closeText }}</button>
|
|
33
|
+
<button mat-raised-button [color]="buttonColor" (click)="closeClicked()">{{ closeText }}</button>
|
|
29
34
|
`,
|
|
30
35
|
host: {
|
|
31
36
|
class: 'dbx-dialog-content-footer'
|
|
@@ -33,7 +38,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
33
38
|
}]
|
|
34
39
|
}], propDecorators: { closeText: [{
|
|
35
40
|
type: Input
|
|
41
|
+
}], buttonColor: [{
|
|
42
|
+
type: Input
|
|
36
43
|
}], close: [{
|
|
37
44
|
type: Output
|
|
45
|
+
}], config: [{
|
|
46
|
+
type: Input
|
|
38
47
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmNvbnRlbnQuZm9vdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9kaWFsb2cvZGlhbG9nLmNvbnRlbnQuZm9vdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFTbEY7O0dBRUc7QUFVSCxNQUFNLE9BQU8sK0JBQStCO0lBVDVDO1FBV0UsY0FBUyxHQUFHLE9BQU8sQ0FBQztRQUdwQixnQkFBVyxHQUFpQixTQUFTLENBQUM7UUFHN0IsVUFBSyxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0FlM0M7SUFiQyxJQUNJLE1BQU0sQ0FBQyxNQUEyQztRQUNwRCxJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sRUFBRSxTQUFTLElBQUksT0FBTyxDQUFDO1FBQzlDLElBQUksQ0FBQyxXQUFXLEdBQUcsTUFBTSxFQUFFLFdBQVcsSUFBSSxTQUFTLENBQUM7SUFDdEQsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDeEIsQ0FBQzs7NkhBdEJVLCtCQUErQjtpSEFBL0IsK0JBQStCLHVPQVBoQzs7R0FFVDs0RkFLVSwrQkFBK0I7a0JBVDNDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsUUFBUSxFQUFFOztHQUVUO29CQUNELElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsMkJBQTJCO3FCQUNuQztpQkFDRjs4QkFHQyxTQUFTO3NCQURSLEtBQUs7Z0JBSU4sV0FBVztzQkFEVixLQUFLO2dCQUlHLEtBQUs7c0JBRGIsTUFBTTtnQkFJSCxNQUFNO3NCQURULEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uRGVzdHJveSwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVtZVBhbGV0dGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4RGlhbG9nQ29udGVudEZvb3RlckNvbmZpZyB7XG4gIGJ1dHRvbkNvbG9yPzogVGhlbWVQYWxldHRlO1xuICBjbG9zZVRleHQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29tcG9uZW50IHVzZWQgdG8gc2hvdyBhIGNsb3NlIGJ1dHRvbiBhdCB0aGUgYm90dG9tIG9mIGEgZGlhbG9nLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtZGlhbG9nLWNvbnRlbnQtZm9vdGVyJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8YnV0dG9uIG1hdC1yYWlzZWQtYnV0dG9uIFtjb2xvcl09XCJidXR0b25Db2xvclwiIChjbGljayk9XCJjbG9zZUNsaWNrZWQoKVwiPnt7IGNsb3NlVGV4dCB9fTwvYnV0dG9uPlxuICBgLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdkYngtZGlhbG9nLWNvbnRlbnQtZm9vdGVyJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIERieERpYWxvZ0NvbnRlbnRGb290ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICBASW5wdXQoKVxuICBjbG9zZVRleHQgPSAnQ2xvc2UnO1xuXG4gIEBJbnB1dCgpXG4gIGJ1dHRvbkNvbG9yOiBUaGVtZVBhbGV0dGUgPSB1bmRlZmluZWQ7XG5cbiAgQE91dHB1dCgpXG4gIHJlYWRvbmx5IGNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIEBJbnB1dCgpXG4gIHNldCBjb25maWcoY29uZmlnOiBNYXliZTxEYnhEaWFsb2dDb250ZW50Rm9vdGVyQ29uZmlnPikge1xuICAgIHRoaXMuY2xvc2VUZXh0ID0gY29uZmlnPy5jbG9zZVRleHQgPz8gJ0Nsb3NlJztcbiAgICB0aGlzLmJ1dHRvbkNvbG9yID0gY29uZmlnPy5idXR0b25Db2xvciA/PyB1bmRlZmluZWQ7XG4gIH1cblxuICBjbG9zZUNsaWNrZWQoKSB7XG4gICAgdGhpcy5jbG9zZS5lbWl0KHVuZGVmaW5lZCk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmNsb3NlLmNvbXBsZXRlKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -196,7 +196,7 @@ export class DbxListComponent {
|
|
|
196
196
|
}
|
|
197
197
|
}
|
|
198
198
|
DbxListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxListComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
199
|
-
DbxListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxListComponent, selector: "dbx-list", inputs: { padded: "padded", state$: "state$", config: "config", disabled: "disabled", selectionMode: "selectionMode" }, outputs: { contentScrolled: "contentScrolled" }, host: { properties: { "class.dbx-list-padded": "padded" }, classAttribute: "d-block dbx-list" }, ngImport: i0, template: "<dbx-loading [context]=\"context\" [linear]=\"true\"></dbx-loading>\n<div dbxListInternalContent infinite-scroll [infiniteScrollDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [infiniteScrollUpDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [hide]=\"hideContent$ | async\" [infiniteScrollThrottle]=\"(throttleScroll$ | async) ?? DEFAULT_THROTTLE_SCROLL\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\" (scrolledUp)=\"onScrollUp()\">\n <ng-content select=\"[top]\"></ng-content>\n <dbx-injection [config]=\"injectedComponentConfig$ | async\"></dbx-injection>\n <ng-content select=\"[bottom]\"></ng-content>\n</div>\n<ng-content *ngIf=\"isEmpty$ | async\" select=\"[empty]\"></ng-content>\n", dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return i2.DbxLoadingComponent; }), selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "context", "loading", "error"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.InfiniteScrollDirective; }), selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: i0.forwardRef(function () { return i4.DbxInjectionComponent; }), selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "directive", type: i0.forwardRef(function () { return DbxListInternalContentDirective; }), selector: "[dbxListInternalContent]", inputs: ["hide"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }] });
|
|
199
|
+
DbxListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxListComponent, selector: "dbx-list", inputs: { padded: "padded", state$: "state$", config: "config", disabled: "disabled", selectionMode: "selectionMode" }, outputs: { contentScrolled: "contentScrolled" }, host: { properties: { "class.dbx-list-padded": "padded" }, classAttribute: "d-block dbx-list" }, ngImport: i0, template: "<dbx-loading [context]=\"context\" [linear]=\"true\"></dbx-loading>\n<div dbxListInternalContent infinite-scroll [infiniteScrollDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [infiniteScrollUpDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [hide]=\"hideContent$ | async\" [infiniteScrollThrottle]=\"(throttleScroll$ | async) ?? DEFAULT_THROTTLE_SCROLL\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\" (scrolledUp)=\"onScrollUp()\">\n <ng-content select=\"[top]\"></ng-content>\n <dbx-injection [config]=\"injectedComponentConfig$ | async\"></dbx-injection>\n <ng-content select=\"[bottom]\"></ng-content>\n</div>\n<ng-content *ngIf=\"isEmpty$ | async\" select=\"[empty]\"></ng-content>\n", dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i1.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i0.forwardRef(function () { return i2.DbxLoadingComponent; }), selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "padding", "context", "loading", "error"] }, { kind: "directive", type: i0.forwardRef(function () { return i3.InfiniteScrollDirective; }), selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: i0.forwardRef(function () { return i4.DbxInjectionComponent; }), selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }, { kind: "directive", type: i0.forwardRef(function () { return DbxListInternalContentDirective; }), selector: "[dbxListInternalContent]", inputs: ["hide"] }, { kind: "pipe", type: i0.forwardRef(function () { return i1.AsyncPipe; }), name: "async" }] });
|
|
200
200
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxListComponent, decorators: [{
|
|
201
201
|
type: Component,
|
|
202
202
|
args: [{ selector: 'dbx-list', host: {
|
|
@@ -248,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
248
248
|
type: HostListener,
|
|
249
249
|
args: ['scroll', ['$event']]
|
|
250
250
|
}] } });
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.component.ts","../../../../../../../packages/dbx-web/src/lib/layout/list/list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { catchError, filter, exhaustMap, merge, map, Subject, switchMap, shareReplay, distinctUntilChanged, of, Observable, BehaviorSubject, first } from 'rxjs';\nimport { Component, Input, EventEmitter, Output, OnDestroy, ElementRef, HostListener, ChangeDetectorRef, Directive } from '@angular/core';\nimport { DbxInjectionComponentConfig, tapDetectChanges } from '@dereekb/dbx-core';\nimport { SubscriptionObject, ListLoadingStateContextInstance, ListLoadingState, filterMaybe, loadingStateHasFinishedLoading, startWithBeginLoading } from '@dereekb/rxjs';\nimport { Maybe, Milliseconds } from '@dereekb/util';\nimport { DbxListSelectionMode, DbxListView, ListSelectionState } from './list.view';\n\n/**\n * Direction the scroll was triggered moving.\n */\nexport type DbxListScrollDirectionTrigger = 'up' | 'down';\n\n/**\n * Used to trigger the loading of additional items.\n *\n * If an observable is returned it is used to throttle the loading of more items until it returns.\n */\nexport type DbxListLoadMoreHandler = () => Observable<void> | void;\n\n/**\n * DbxListComponent configuration.\n */\nexport interface DbxListConfig<T = unknown, V extends DbxListView<T> = DbxListView<T>> extends DbxInjectionComponentConfig<V> {\n  /**\n   * Whether or not to hide the list content when it is an empty list.\n   */\n  hideOnEmpty?: boolean;\n\n  /**\n   * Whether or not this list should scroll upward from the bottom, like a message list.\n   */\n  invertedList?: boolean;\n\n  /**\n   * Distance to scroll.\n   */\n  scrollDistance?: number;\n\n  /**\n   * Number of ms to throttle scrolling events.\n   */\n  throttle?: Milliseconds;\n\n  /**\n   * (Optional) onClick handler\n   */\n  onClick?: (value: T) => void;\n\n  /**\n   * (Optional) onSelection handler\n   */\n  onSelectionChange?: (selection: ListSelectionState<T>) => void;\n\n  /**\n   * (Optional) handler function to load more items.\n   */\n  loadMore?: DbxListLoadMoreHandler;\n\n  /**\n   * Default selection list value. If not defined, will default to 'view'.\n   */\n  defaultSelectionMode?: Maybe<DbxListSelectionMode>;\n}\n\n/**\n * Used to display a potentially infinitely scrollable list of content.\n *\n * This component is generally wrapped by another component that provides this one configuration.\n */\n@Component({\n  selector: 'dbx-list',\n  templateUrl: './list.component.html',\n  host: {\n    class: 'd-block dbx-list',\n    '[class.dbx-list-padded]': 'padded'\n  }\n})\nexport class DbxListComponent<T = unknown, V extends DbxListView<T> = DbxListView<T>, S extends ListLoadingState<T> = ListLoadingState<T>> implements OnDestroy {\n  readonly DEFAULT_SCROLL_DISTANCE = 1.5;\n  readonly DEFAULT_THROTTLE_SCROLL = 50;\n\n  /**\n   * Whether or not to add bottom padding to the list content.\n   */\n  @Input()\n  padded = true;\n\n  @Output()\n  contentScrolled = new EventEmitter<number>();\n\n  private _content: Maybe<DbxListInternalContentDirective>;\n  private _disabled = new BehaviorSubject<boolean>(false);\n  private _selectionMode = new BehaviorSubject<Maybe<DbxListSelectionMode>>(undefined);\n\n  private _loadMoreTrigger = new Subject<void>();\n  private _scrollTrigger = new Subject<DbxListScrollDirectionTrigger>();\n  private _config = new BehaviorSubject<Maybe<DbxListConfig<T, V>>>(undefined);\n\n  private _loadMoreSub = new SubscriptionObject();\n  private _onClickSub = new SubscriptionObject();\n  private _disabledSub = new SubscriptionObject();\n  private _selectionModeSub = new SubscriptionObject();\n  private _onSelectionChangeSub = new SubscriptionObject();\n\n  readonly context = new ListLoadingStateContextInstance<T, S>({ showLoadingOnNoValue: false });\n  readonly isEmpty$ = this.context.isEmpty$;\n  readonly disabled$ = this._disabled.asObservable();\n  readonly selectionMode$ = this._selectionMode.asObservable();\n\n  readonly hideOnEmpty$: Observable<boolean> = this._config.pipe(\n    filterMaybe(),\n    map((x) => Boolean(x.hideOnEmpty)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n  readonly invertedList$: Observable<boolean> = this._config.pipe(\n    filterMaybe(),\n    map((x) => Boolean(x?.throttle)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n  readonly throttleScroll$: Observable<number> = this._config.pipe(\n    map((x) => x?.throttle ?? this.DEFAULT_THROTTLE_SCROLL),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n  readonly scrollDistance$: Observable<number> = this._config.pipe(\n    map((x) => x?.scrollDistance ?? this.DEFAULT_SCROLL_DISTANCE),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly scrollLoadMoreTrigger$ = this._config.pipe(\n    switchMap((config) => {\n      const loadNextDirection = config?.invertedList ? 'up' : 'down';\n      return this._scrollTrigger.pipe(filter((x) => x === loadNextDirection));\n    })\n  );\n\n  readonly loadMore$ = merge(this.scrollLoadMoreTrigger$, this._loadMoreTrigger);\n\n  readonly injectedComponentConfig$: Observable<Maybe<DbxInjectionComponentConfig<V>>> = this._config.pipe(\n    distinctUntilChanged(),\n    map((config) => {\n      let injectedComponentConfig: Maybe<DbxInjectionComponentConfig<V>>;\n\n      if (config) {\n        const { componentClass, init, onClick, onSelectionChange, loadMore, defaultSelectionMode = 'view' } = config;\n\n        injectedComponentConfig = {\n          componentClass: config.componentClass,\n          injector: config.injector,\n          init: (instance: V) => {\n            // Synchronize disabled\n            this._disabledSub.subscription = this.disabled$.subscribe((disabled) => instance.setDisabled(disabled));\n            this._selectionModeSub.subscription = this.selectionMode$.subscribe((selectionMode) => instance.setSelectionMode(selectionMode ?? defaultSelectionMode));\n\n            if (init) {\n              init(instance);\n            }\n\n            instance.setListContext(this.context);\n\n            if (loadMore) {\n              this._loadMoreSub.subscription = this.loadMore$\n                .pipe(\n                  // Throttle additional loading calls using exhaustMap until observable returns, if one is returned.\n                  exhaustMap(() => {\n                    const result = loadMore();\n                    let obs: Observable<void>;\n\n                    if (result) {\n                      obs = result.pipe(catchError(() => of()));\n                    } else {\n                      obs = of();\n                    }\n\n                    return obs;\n                  })\n                )\n                .subscribe();\n            }\n\n            if (onClick) {\n              if (instance.clickValue) {\n                this._onClickSub.subscription = instance.clickValue.subscribe(onClick);\n              } else {\n                console.error(`onClick() was passed to listConfig, but target class ${componentClass} has no clicked event emitter.`);\n              }\n            }\n\n            if (onSelectionChange) {\n              if (instance.selectionChange) {\n                this._onSelectionChangeSub.subscription = instance.selectionChange.subscribe(onSelectionChange);\n              } else {\n                console.error(`onSelectionChange() was passed to listConfig, but target class ${componentClass} has no selectionChange event emitter.`);\n              }\n            }\n          }\n        };\n      }\n\n      return injectedComponentConfig;\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly hideContent$: Observable<boolean> = this.context.stateChange$.pipe(\n    switchMap(() =>\n      this.context.state$.pipe(\n        filter((x) => loadingStateHasFinishedLoading(x)),\n        first(),\n        startWithBeginLoading()\n      )\n    ),\n    switchMap((state) => {\n      if (state?.loading) {\n        return of(true);\n      } else {\n        return this.hideOnEmpty$.pipe(\n          switchMap((hide) => (hide === false ? of(false) : this.isEmpty$)),\n          distinctUntilChanged(),\n          tapDetectChanges(this.cdRef),\n          shareReplay(1)\n        );\n      }\n    })\n  );\n\n  constructor(readonly cdRef: ChangeDetectorRef) {}\n\n  ngOnDestroy(): void {\n    delete this._content; // remove parent-child relation.\n    this._scrollTrigger.complete();\n    this._loadMoreTrigger.complete();\n    this._config.complete();\n    this._disabled.complete();\n    this._selectionMode.complete();\n\n    this._onClickSub.destroy();\n    this._loadMoreSub.destroy();\n    this._onSelectionChangeSub.destroy();\n    this._disabledSub.destroy();\n\n    this.context.destroy();\n  }\n\n  @Input()\n  get state$(): Observable<S> {\n    return this.context.state$;\n  }\n\n  set state$(state$: Maybe<Observable<S>>) {\n    this.context.setStateObs(state$);\n  }\n\n  @Input()\n  set config(config: Maybe<DbxListConfig<T, V>>) {\n    this._config.next(config);\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled.value;\n  }\n\n  set disabled(disabled: Maybe<boolean>) {\n    this._disabled.next(disabled ?? false);\n  }\n\n  @Input()\n  get selectionMode(): Maybe<DbxListSelectionMode> {\n    return this._selectionMode.value;\n  }\n\n  set selectionMode(selectionMode: Maybe<DbxListSelectionMode>) {\n    this._selectionMode.next(selectionMode);\n  }\n\n  getScrollPositionRelativeToBottom(): number {\n    try {\n      const element = this.nativeElement;\n\n      // At max scroll, scrollHeight = scrollTop + clientHeight;\n      const { scrollTop, scrollHeight, clientHeight } = element;\n      return scrollHeight - (scrollTop + clientHeight);\n    } catch (e) {\n      return 0;\n    }\n  }\n\n  jumpToBottom(): void {\n    try {\n      this.nativeElement.scrollTop = this.nativeElement.scrollHeight;\n    } catch (err) {\n      // do nothing.\n    }\n  }\n\n  jumpToPositionRelativeToBottom(pos: number): void {\n    try {\n      const element = this.nativeElement;\n      const { scrollHeight, clientHeight } = element;\n      element.scrollTop = scrollHeight - (clientHeight + pos);\n    } catch (err) {\n      // do nothing.\n    }\n  }\n\n  onScrollDown(): void {\n    this._scrollTrigger.next('down');\n  }\n\n  onScrollUp(): void {\n    this._scrollTrigger.next('up');\n  }\n\n  loadMore(): void {\n    this._loadMoreTrigger.next();\n  }\n\n  // MARK: Internal\n  get nativeElement() {\n    return this.__content.elementRef.nativeElement;\n  }\n\n  get __content(): DbxListInternalContentDirective {\n    return this._content as DbxListInternalContentDirective;\n  }\n\n  set __content(content: DbxListInternalContentDirective) {\n    if (this._content == null) {\n      this._content = content;\n    } else {\n      throw new Error('Attempted to set __content in list outside of initialization.');\n    }\n  }\n}\n\n/**\n * Used internally by DbxListComponent\n */\n@Directive({\n  selector: '[dbxListInternalContent]',\n  host: {\n    class: 'd-block dbx-list-content',\n    '[class.dbx-list-content-hidden]': 'hide'\n  }\n})\nexport class DbxListInternalContentDirective {\n  @Input()\n  hide: Maybe<boolean> = false;\n\n  constructor(private readonly parent: DbxListComponent, readonly elementRef: ElementRef) {\n    this.parent.__content = this;\n  }\n\n  @HostListener('scroll', ['$event'])\n  onScrollEvent($event: Event): void {\n    const position = ($event.target as Element).scrollTop;\n    this.parent.contentScrolled.emit(position);\n  }\n}\n","<dbx-loading [context]=\"context\" [linear]=\"true\"></dbx-loading>\n<div dbxListInternalContent infinite-scroll [infiniteScrollDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [infiniteScrollUpDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [hide]=\"hideContent$ | async\" [infiniteScrollThrottle]=\"(throttleScroll$ | async) ?? DEFAULT_THROTTLE_SCROLL\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\" (scrolledUp)=\"onScrollUp()\">\n  <ng-content select=\"[top]\"></ng-content>\n  <dbx-injection [config]=\"injectedComponentConfig$ | async\"></dbx-injection>\n  <ng-content select=\"[bottom]\"></ng-content>\n</div>\n<ng-content *ngIf=\"isEmpty$ | async\" select=\"[empty]\"></ng-content>\n"]}
|
|
251
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.component.ts","../../../../../../../packages/dbx-web/src/lib/layout/list/list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { catchError, filter, exhaustMap, merge, map, Subject, switchMap, shareReplay, distinctUntilChanged, of, Observable, BehaviorSubject, first } from 'rxjs';\nimport { Component, Input, EventEmitter, Output, OnDestroy, ElementRef, HostListener, ChangeDetectorRef, Directive } from '@angular/core';\nimport { DbxInjectionComponentConfig, tapDetectChanges } from '@dereekb/dbx-core';\nimport { SubscriptionObject, ListLoadingStateContextInstance, ListLoadingState, filterMaybe, loadingStateHasFinishedLoading, startWithBeginLoading } from '@dereekb/rxjs';\nimport { Maybe, Milliseconds } from '@dereekb/util';\nimport { DbxListSelectionMode, DbxListView, ListSelectionState } from './list.view';\n\n/**\n * Direction the scroll was triggered moving.\n */\nexport type DbxListScrollDirectionTrigger = 'up' | 'down';\n\n/**\n * Used to trigger the loading of additional items.\n *\n * If an observable is returned it is used to throttle the loading of more items until it returns.\n */\nexport type DbxListLoadMoreHandler = () => Observable<void> | void;\n\n/**\n * DbxListComponent configuration.\n */\nexport interface DbxListConfig<T = unknown, V extends DbxListView<T> = DbxListView<T>> extends DbxInjectionComponentConfig<V> {\n  /**\n   * Whether or not to hide the list content when it is an empty list.\n   */\n  hideOnEmpty?: boolean;\n\n  /**\n   * Whether or not this list should scroll upward from the bottom, like a message list.\n   */\n  invertedList?: boolean;\n\n  /**\n   * Distance to scroll.\n   */\n  scrollDistance?: number;\n\n  /**\n   * Number of ms to throttle scrolling events.\n   */\n  throttle?: Milliseconds;\n\n  /**\n   * (Optional) onClick handler\n   */\n  onClick?: (value: T) => void;\n\n  /**\n   * (Optional) onSelection handler\n   */\n  onSelectionChange?: (selection: ListSelectionState<T>) => void;\n\n  /**\n   * (Optional) handler function to load more items.\n   */\n  loadMore?: DbxListLoadMoreHandler;\n\n  /**\n   * Default selection list value. If not defined, will default to 'view'.\n   */\n  defaultSelectionMode?: Maybe<DbxListSelectionMode>;\n}\n\n/**\n * Used to display a potentially infinitely scrollable list of content.\n *\n * This component is generally wrapped by another component that provides this one configuration.\n */\n@Component({\n  selector: 'dbx-list',\n  templateUrl: './list.component.html',\n  host: {\n    class: 'd-block dbx-list',\n    '[class.dbx-list-padded]': 'padded'\n  }\n})\nexport class DbxListComponent<T = unknown, V extends DbxListView<T> = DbxListView<T>, S extends ListLoadingState<T> = ListLoadingState<T>> implements OnDestroy {\n  readonly DEFAULT_SCROLL_DISTANCE = 1.5;\n  readonly DEFAULT_THROTTLE_SCROLL = 50;\n\n  /**\n   * Whether or not to add bottom padding to the list content.\n   */\n  @Input()\n  padded = true;\n\n  @Output()\n  contentScrolled = new EventEmitter<number>();\n\n  private _content: Maybe<DbxListInternalContentDirective>;\n  private _disabled = new BehaviorSubject<boolean>(false);\n  private _selectionMode = new BehaviorSubject<Maybe<DbxListSelectionMode>>(undefined);\n\n  private _loadMoreTrigger = new Subject<void>();\n  private _scrollTrigger = new Subject<DbxListScrollDirectionTrigger>();\n  private _config = new BehaviorSubject<Maybe<DbxListConfig<T, V>>>(undefined);\n\n  private _loadMoreSub = new SubscriptionObject();\n  private _onClickSub = new SubscriptionObject();\n  private _disabledSub = new SubscriptionObject();\n  private _selectionModeSub = new SubscriptionObject();\n  private _onSelectionChangeSub = new SubscriptionObject();\n\n  readonly context = new ListLoadingStateContextInstance<T, S>({ showLoadingOnNoValue: false });\n  readonly isEmpty$ = this.context.isEmpty$;\n  readonly disabled$ = this._disabled.asObservable();\n  readonly selectionMode$ = this._selectionMode.asObservable();\n\n  readonly hideOnEmpty$: Observable<boolean> = this._config.pipe(\n    filterMaybe(),\n    map((x) => Boolean(x.hideOnEmpty)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n  readonly invertedList$: Observable<boolean> = this._config.pipe(\n    filterMaybe(),\n    map((x) => Boolean(x?.throttle)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n  readonly throttleScroll$: Observable<number> = this._config.pipe(\n    map((x) => x?.throttle ?? this.DEFAULT_THROTTLE_SCROLL),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n  readonly scrollDistance$: Observable<number> = this._config.pipe(\n    map((x) => x?.scrollDistance ?? this.DEFAULT_SCROLL_DISTANCE),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly scrollLoadMoreTrigger$ = this._config.pipe(\n    switchMap((config) => {\n      const loadNextDirection = config?.invertedList ? 'up' : 'down';\n      return this._scrollTrigger.pipe(filter((x) => x === loadNextDirection));\n    })\n  );\n\n  readonly loadMore$ = merge(this.scrollLoadMoreTrigger$, this._loadMoreTrigger);\n\n  readonly injectedComponentConfig$: Observable<Maybe<DbxInjectionComponentConfig<V>>> = this._config.pipe(\n    distinctUntilChanged(),\n    map((config) => {\n      let injectedComponentConfig: Maybe<DbxInjectionComponentConfig<V>>;\n\n      if (config) {\n        const { componentClass, init, onClick, onSelectionChange, loadMore, defaultSelectionMode = 'view' } = config;\n\n        injectedComponentConfig = {\n          componentClass: config.componentClass,\n          injector: config.injector,\n          init: (instance: V) => {\n            // Synchronize disabled\n            this._disabledSub.subscription = this.disabled$.subscribe((disabled) => instance.setDisabled(disabled));\n            this._selectionModeSub.subscription = this.selectionMode$.subscribe((selectionMode) => instance.setSelectionMode(selectionMode ?? defaultSelectionMode));\n\n            if (init) {\n              init(instance);\n            }\n\n            instance.setListContext(this.context);\n\n            if (loadMore) {\n              this._loadMoreSub.subscription = this.loadMore$\n                .pipe(\n                  // Throttle additional loading calls using exhaustMap until observable returns, if one is returned.\n                  exhaustMap(() => {\n                    const result = loadMore();\n                    let obs: Observable<void>;\n\n                    if (result) {\n                      obs = result.pipe(catchError(() => of()));\n                    } else {\n                      obs = of();\n                    }\n\n                    return obs;\n                  })\n                )\n                .subscribe();\n            }\n\n            if (onClick) {\n              if (instance.clickValue) {\n                this._onClickSub.subscription = instance.clickValue.subscribe(onClick);\n              } else {\n                console.error(`onClick() was passed to listConfig, but target class ${componentClass} has no clicked event emitter.`);\n              }\n            }\n\n            if (onSelectionChange) {\n              if (instance.selectionChange) {\n                this._onSelectionChangeSub.subscription = instance.selectionChange.subscribe(onSelectionChange);\n              } else {\n                console.error(`onSelectionChange() was passed to listConfig, but target class ${componentClass} has no selectionChange event emitter.`);\n              }\n            }\n          }\n        };\n      }\n\n      return injectedComponentConfig;\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly hideContent$: Observable<boolean> = this.context.stateChange$.pipe(\n    switchMap(() =>\n      this.context.state$.pipe(\n        filter((x) => loadingStateHasFinishedLoading(x)),\n        first(),\n        startWithBeginLoading()\n      )\n    ),\n    switchMap((state) => {\n      if (state?.loading) {\n        return of(true);\n      } else {\n        return this.hideOnEmpty$.pipe(\n          switchMap((hide) => (hide === false ? of(false) : this.isEmpty$)),\n          distinctUntilChanged(),\n          tapDetectChanges(this.cdRef),\n          shareReplay(1)\n        );\n      }\n    })\n  );\n\n  constructor(readonly cdRef: ChangeDetectorRef) {}\n\n  ngOnDestroy(): void {\n    delete this._content; // remove parent-child relation.\n    this._scrollTrigger.complete();\n    this._loadMoreTrigger.complete();\n    this._config.complete();\n    this._disabled.complete();\n    this._selectionMode.complete();\n\n    this._onClickSub.destroy();\n    this._loadMoreSub.destroy();\n    this._onSelectionChangeSub.destroy();\n    this._disabledSub.destroy();\n\n    this.context.destroy();\n  }\n\n  @Input()\n  get state$(): Observable<S> {\n    return this.context.state$;\n  }\n\n  set state$(state$: Maybe<Observable<S>>) {\n    this.context.setStateObs(state$);\n  }\n\n  @Input()\n  set config(config: Maybe<DbxListConfig<T, V>>) {\n    this._config.next(config);\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled.value;\n  }\n\n  set disabled(disabled: Maybe<boolean>) {\n    this._disabled.next(disabled ?? false);\n  }\n\n  @Input()\n  get selectionMode(): Maybe<DbxListSelectionMode> {\n    return this._selectionMode.value;\n  }\n\n  set selectionMode(selectionMode: Maybe<DbxListSelectionMode>) {\n    this._selectionMode.next(selectionMode);\n  }\n\n  getScrollPositionRelativeToBottom(): number {\n    try {\n      const element = this.nativeElement;\n\n      // At max scroll, scrollHeight = scrollTop + clientHeight;\n      const { scrollTop, scrollHeight, clientHeight } = element;\n      return scrollHeight - (scrollTop + clientHeight);\n    } catch (e) {\n      return 0;\n    }\n  }\n\n  jumpToBottom(): void {\n    try {\n      this.nativeElement.scrollTop = this.nativeElement.scrollHeight;\n    } catch (err) {\n      // do nothing.\n    }\n  }\n\n  jumpToPositionRelativeToBottom(pos: number): void {\n    try {\n      const element = this.nativeElement;\n      const { scrollHeight, clientHeight } = element;\n      element.scrollTop = scrollHeight - (clientHeight + pos);\n    } catch (err) {\n      // do nothing.\n    }\n  }\n\n  onScrollDown(): void {\n    this._scrollTrigger.next('down');\n  }\n\n  onScrollUp(): void {\n    this._scrollTrigger.next('up');\n  }\n\n  loadMore(): void {\n    this._loadMoreTrigger.next();\n  }\n\n  // MARK: Internal\n  get nativeElement() {\n    return this.__content.elementRef.nativeElement;\n  }\n\n  get __content(): DbxListInternalContentDirective {\n    return this._content as DbxListInternalContentDirective;\n  }\n\n  set __content(content: DbxListInternalContentDirective) {\n    if (this._content == null) {\n      this._content = content;\n    } else {\n      throw new Error('Attempted to set __content in list outside of initialization.');\n    }\n  }\n}\n\n/**\n * Used internally by DbxListComponent\n */\n@Directive({\n  selector: '[dbxListInternalContent]',\n  host: {\n    class: 'd-block dbx-list-content',\n    '[class.dbx-list-content-hidden]': 'hide'\n  }\n})\nexport class DbxListInternalContentDirective {\n  @Input()\n  hide: Maybe<boolean> = false;\n\n  constructor(private readonly parent: DbxListComponent, readonly elementRef: ElementRef) {\n    this.parent.__content = this;\n  }\n\n  @HostListener('scroll', ['$event'])\n  onScrollEvent($event: Event): void {\n    const position = ($event.target as Element).scrollTop;\n    this.parent.contentScrolled.emit(position);\n  }\n}\n","<dbx-loading [context]=\"context\" [linear]=\"true\"></dbx-loading>\n<div dbxListInternalContent infinite-scroll [infiniteScrollDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [infiniteScrollUpDistance]=\"(scrollDistance$ | async) ?? DEFAULT_SCROLL_DISTANCE\" [hide]=\"hideContent$ | async\" [infiniteScrollThrottle]=\"(throttleScroll$ | async) ?? DEFAULT_THROTTLE_SCROLL\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\" (scrolledUp)=\"onScrollUp()\">\n  <ng-content select=\"[top]\"></ng-content>\n  <dbx-injection [config]=\"injectedComponentConfig$ | async\"></dbx-injection>\n  <ng-content select=\"[bottom]\"></ng-content>\n</div>\n<ng-content *ngIf=\"isEmpty$ | async\" select=\"[empty]\"></ng-content>\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { BehaviorSubject, shareReplay, distinctUntilChanged, map, switchMap, combineLatest, of } from 'rxjs';
|
|
2
2
|
import { Component, Input } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
-
import * as i2 from "
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "./basic-loading.component";
|
|
6
6
|
/**
|
|
7
7
|
* Loading View component that provides content sections for loading, error, and an error action.
|
|
8
8
|
*/
|
|
@@ -52,14 +52,15 @@ export class DbxLoadingComponent {
|
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
54
|
DbxLoadingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxLoadingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
55
|
-
DbxLoadingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxLoadingComponent, selector: "dbx-loading", inputs: { show: "show", text: "text", mode: "mode", color: "color", diameter: "diameter", linear: "linear", context: "context", loading: "loading", error: "error" }, ngImport: i0, template: `
|
|
55
|
+
DbxLoadingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxLoadingComponent, selector: "dbx-loading", inputs: { show: "show", text: "text", mode: "mode", color: "color", diameter: "diameter", linear: "linear", padding: "padding", context: "context", loading: "loading", error: "error" }, ngImport: i0, template: `
|
|
56
56
|
<dbx-basic-loading [show]="show" [color]="color" [text]="text" [mode]="mode" [linear]="linear" [diameter]="diameter" [error]="error$ | async" [loading]="loading$ | async">
|
|
57
57
|
<ng-content loading select="[loading]"></ng-content>
|
|
58
|
+
<div class="dbx-loading-linear-done-padding" *ngIf="linear && padding && !(loading$ | async)"></div>
|
|
58
59
|
<ng-content></ng-content>
|
|
59
60
|
<ng-content error select="[error]"></ng-content>
|
|
60
61
|
<ng-content errorAction select="[errorAction]"></ng-content>
|
|
61
62
|
</dbx-basic-loading>
|
|
62
|
-
`, isInline: true, dependencies: [{ kind: "
|
|
63
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DbxBasicLoadingComponent, selector: "dbx-basic-loading", inputs: ["diameter", "mode", "color", "text", "linear", "show", "loading", "error"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
|
|
63
64
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxLoadingComponent, decorators: [{
|
|
64
65
|
type: Component,
|
|
65
66
|
args: [{
|
|
@@ -67,6 +68,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
67
68
|
template: `
|
|
68
69
|
<dbx-basic-loading [show]="show" [color]="color" [text]="text" [mode]="mode" [linear]="linear" [diameter]="diameter" [error]="error$ | async" [loading]="loading$ | async">
|
|
69
70
|
<ng-content loading select="[loading]"></ng-content>
|
|
71
|
+
<div class="dbx-loading-linear-done-padding" *ngIf="linear && padding && !(loading$ | async)"></div>
|
|
70
72
|
<ng-content></ng-content>
|
|
71
73
|
<ng-content error select="[error]"></ng-content>
|
|
72
74
|
<ng-content errorAction select="[errorAction]"></ng-content>
|
|
@@ -85,6 +87,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
85
87
|
type: Input
|
|
86
88
|
}], linear: [{
|
|
87
89
|
type: Input
|
|
90
|
+
}], padding: [{
|
|
91
|
+
type: Input
|
|
88
92
|
}], context: [{
|
|
89
93
|
type: Input
|
|
90
94
|
}], loading: [{
|
|
@@ -92,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
92
96
|
}], error: [{
|
|
93
97
|
type: Input
|
|
94
98
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loading.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-web/src/lib/loading/loading.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, shareReplay, Observable, distinctUntilChanged, map, switchMap, combineLatest, of } from 'rxjs';\nimport { OnDestroy, Component, Input } from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { ProgressBarMode } from '@angular/material/progress-bar';\nimport { LoadingContext } from '@dereekb/rxjs';\nimport { ErrorInput, Maybe } from '@dereekb/util';\n\nexport interface DbxLoadingComponentState {\n  loading: boolean;\n  error: Maybe<ErrorInput>;\n}\n\n/**\n * Loading View component that provides content sections for loading, error, and an error action.\n */\n@Component({\n  selector: 'dbx-loading',\n  template: `\n    <dbx-basic-loading [show]=\"show\" [color]=\"color\" [text]=\"text\" [mode]=\"mode\" [linear]=\"linear\" [diameter]=\"diameter\" [error]=\"error$ | async\" [loading]=\"loading$ | async\">\n      <ng-content loading select=\"[loading]\"></ng-content>\n      <div class=\"dbx-loading-linear-done-padding\" *ngIf=\"linear && padding && !(loading$ | async)\"></div>\n      <ng-content></ng-content>\n      <ng-content error select=\"[error]\"></ng-content>\n      <ng-content errorAction select=\"[errorAction]\"></ng-content>\n    </dbx-basic-loading>\n  `\n})\nexport class DbxLoadingComponent implements OnDestroy {\n  private _context = new BehaviorSubject<Maybe<LoadingContext>>(undefined);\n\n  private _inputLoading = new BehaviorSubject<Maybe<boolean>>(true);\n  private _inputError = new BehaviorSubject<Maybe<ErrorInput>>(undefined);\n\n  readonly state$: Observable<DbxLoadingComponentState> = combineLatest([this._inputLoading, this._inputError, this._context.pipe(switchMap((x) => (x != null ? x.stream$ : of(undefined))))]).pipe(\n    map(([inputLoading, inputError, loadingState]) => {\n      if (loadingState) {\n        return loadingState as DbxLoadingComponentState;\n      } else {\n        return {\n          loading: inputLoading ?? false,\n          error: inputError\n        };\n      }\n    }),\n    distinctUntilChanged((a, b) => a.loading === b.loading && a.error === b.error),\n    shareReplay(1)\n  );\n\n  readonly loading$ = this.state$.pipe(\n    map((x) => x.loading),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n  readonly error$ = this.state$.pipe(\n    map((x) => x.error),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  @Input()\n  show?: Maybe<boolean>;\n\n  @Input()\n  text?: Maybe<string>;\n\n  @Input()\n  mode: ProgressBarMode = 'indeterminate';\n\n  @Input()\n  color: ThemePalette = 'primary';\n\n  @Input()\n  diameter?: Maybe<number>;\n\n  @Input()\n  linear?: Maybe<boolean>;\n\n  /**\n   * Whether or not to add padding to the linear presentation when linear is complete. This prevents the linear bar from pushing content around.\n   */\n  @Input()\n  padding?: Maybe<boolean>;\n\n  ngOnDestroy() {\n    this._context.complete();\n    this._inputError.complete();\n    this._inputLoading.complete();\n  }\n\n  @Input()\n  get context(): Maybe<LoadingContext> {\n    return this._context.value;\n  }\n\n  set context(context: Maybe<LoadingContext>) {\n    this._context.next(context);\n  }\n\n  @Input()\n  get loading(): Maybe<boolean> {\n    return this._inputLoading.value;\n  }\n\n  set loading(loading: Maybe<boolean>) {\n    this._inputLoading.next(loading ?? false);\n  }\n\n  @Input()\n  get error(): Maybe<ErrorInput> {\n    return this._inputError.value;\n  }\n\n  set error(error: Maybe<ErrorInput>) {\n    this._inputError.next(error);\n  }\n}\n"]}
|
|
@@ -50,7 +50,7 @@ export class DbxTableViewComponent {
|
|
|
50
50
|
}
|
|
51
51
|
}
|
|
52
52
|
DbxTableViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableViewComponent, deps: [{ token: i1.DbxTableStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
-
DbxTableViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableViewComponent, selector: "dbx-table-view", ngImport: i0, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollThrottle]=\"throttleScroll\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elements$\" [trackBy]=\"(trackByFunction$ | async) || DEFAULT_TRACK_BY_FUNCTION\">\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [element]=\"element\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\" *ngFor=\"let column of innerColumns$ | async\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [element]=\"element\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [element]=\"element\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns$ | async\"></tr>\n\n <tr mat-footer-row *matFooterRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n </table>\n </section>\n</dbx-loading>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.DbxLoadingComponent, selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "context", "loading", "error"] }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i4.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i4.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i4.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "directive", type: i5.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: i6.DbxTableColumnHeaderComponent, selector: "dbx-table-column-header" }, { kind: "component", type: i7.DbxTableColumnFooterComponent, selector: "dbx-table-column-footer" }, { kind: "component", type: i8.DbxTableInputCellComponent, selector: "dbx-table-input-cell" }, { kind: "component", type: i9.DbxTableActionCellComponent, selector: "dbx-table-action-cell" }, { kind: "component", type: i10.DbxTableItemCellComponent, selector: "dbx-table-item-cell", inputs: ["column"] }, { kind: "component", type: i11.DbxTableItemHeaderComponent, selector: "dbx-table-item-header" }, { kind: "component", type: i12.DbxTableItemActionComponent, selector: "dbx-table-item-action" }, { kind: "component", type: i13.DbxTableSummaryStartCellComponent, selector: "dbx-table-summary-start-cell" }, { kind: "component", type: i14.DbxTableSummaryEndCellComponent, selector: "dbx-table-summary-end-cell" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
53
|
+
DbxTableViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableViewComponent, selector: "dbx-table-view", ngImport: i0, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollThrottle]=\"throttleScroll\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elements$\" [trackBy]=\"(trackByFunction$ | async) || DEFAULT_TRACK_BY_FUNCTION\">\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [element]=\"element\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\" *ngFor=\"let column of innerColumns$ | async\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [element]=\"element\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [element]=\"element\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns$ | async\"></tr>\n\n <tr mat-footer-row *matFooterRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n </table>\n </section>\n</dbx-loading>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.DbxLoadingComponent, selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "padding", "context", "loading", "error"] }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i4.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i4.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i4.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "directive", type: i5.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: i6.DbxTableColumnHeaderComponent, selector: "dbx-table-column-header" }, { kind: "component", type: i7.DbxTableColumnFooterComponent, selector: "dbx-table-column-footer" }, { kind: "component", type: i8.DbxTableInputCellComponent, selector: "dbx-table-input-cell" }, { kind: "component", type: i9.DbxTableActionCellComponent, selector: "dbx-table-action-cell" }, { kind: "component", type: i10.DbxTableItemCellComponent, selector: "dbx-table-item-cell", inputs: ["column"] }, { kind: "component", type: i11.DbxTableItemHeaderComponent, selector: "dbx-table-item-header" }, { kind: "component", type: i12.DbxTableItemActionComponent, selector: "dbx-table-item-action" }, { kind: "component", type: i13.DbxTableSummaryStartCellComponent, selector: "dbx-table-summary-start-cell" }, { kind: "component", type: i14.DbxTableSummaryEndCellComponent, selector: "dbx-table-summary-end-cell" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
54
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableViewComponent, decorators: [{
|
|
55
55
|
type: Component,
|
|
56
56
|
args: [{ selector: 'dbx-table-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollThrottle]=\"throttleScroll\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elements$\" [trackBy]=\"(trackByFunction$ | async) || DEFAULT_TRACK_BY_FUNCTION\">\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [element]=\"element\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\" *ngFor=\"let column of innerColumns$ | async\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [element]=\"element\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [element]=\"element\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns$ | async\"></tr>\n\n <tr mat-footer-row *matFooterRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n </table>\n </section>\n</dbx-loading>\n" }]
|
|
@@ -640,7 +640,7 @@ class DbxTableViewComponent {
|
|
|
640
640
|
}
|
|
641
641
|
}
|
|
642
642
|
DbxTableViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableViewComponent, deps: [{ token: DbxTableStore }], target: i0.ɵɵFactoryTarget.Component });
|
|
643
|
-
DbxTableViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableViewComponent, selector: "dbx-table-view", ngImport: i0, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollThrottle]=\"throttleScroll\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elements$\" [trackBy]=\"(trackByFunction$ | async) || DEFAULT_TRACK_BY_FUNCTION\">\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [element]=\"element\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\" *ngFor=\"let column of innerColumns$ | async\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [element]=\"element\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [element]=\"element\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns$ | async\"></tr>\n\n <tr mat-footer-row *matFooterRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n </table>\n </section>\n</dbx-loading>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3$1.DbxLoadingComponent, selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "context", "loading", "error"] }, { kind: "component", type: i4$1.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4$1.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4$1.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4$1.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4$1.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4$1.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4$1.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i4$1.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i4$1.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4$1.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i4$1.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i4$1.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4$1.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i4$1.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "directive", type: i5$1.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: DbxTableColumnHeaderComponent, selector: "dbx-table-column-header" }, { kind: "component", type: DbxTableColumnFooterComponent, selector: "dbx-table-column-footer" }, { kind: "component", type: DbxTableInputCellComponent, selector: "dbx-table-input-cell" }, { kind: "component", type: DbxTableActionCellComponent, selector: "dbx-table-action-cell" }, { kind: "component", type: DbxTableItemCellComponent, selector: "dbx-table-item-cell", inputs: ["column"] }, { kind: "component", type: DbxTableItemHeaderComponent, selector: "dbx-table-item-header" }, { kind: "component", type: DbxTableItemActionComponent, selector: "dbx-table-item-action" }, { kind: "component", type: DbxTableSummaryStartCellComponent, selector: "dbx-table-summary-start-cell" }, { kind: "component", type: DbxTableSummaryEndCellComponent, selector: "dbx-table-summary-end-cell" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
643
|
+
DbxTableViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxTableViewComponent, selector: "dbx-table-view", ngImport: i0, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollThrottle]=\"throttleScroll\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elements$\" [trackBy]=\"(trackByFunction$ | async) || DEFAULT_TRACK_BY_FUNCTION\">\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [element]=\"element\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\" *ngFor=\"let column of innerColumns$ | async\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [element]=\"element\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [element]=\"element\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns$ | async\"></tr>\n\n <tr mat-footer-row *matFooterRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n </table>\n </section>\n</dbx-loading>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3$1.DbxLoadingComponent, selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "padding", "context", "loading", "error"] }, { kind: "component", type: i4$1.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4$1.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4$1.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4$1.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4$1.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4$1.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4$1.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i4$1.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i4$1.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4$1.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i4$1.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i4$1.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4$1.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i4$1.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "directive", type: i5$1.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: DbxTableColumnHeaderComponent, selector: "dbx-table-column-header" }, { kind: "component", type: DbxTableColumnFooterComponent, selector: "dbx-table-column-footer" }, { kind: "component", type: DbxTableInputCellComponent, selector: "dbx-table-input-cell" }, { kind: "component", type: DbxTableActionCellComponent, selector: "dbx-table-action-cell" }, { kind: "component", type: DbxTableItemCellComponent, selector: "dbx-table-item-cell", inputs: ["column"] }, { kind: "component", type: DbxTableItemHeaderComponent, selector: "dbx-table-item-header" }, { kind: "component", type: DbxTableItemActionComponent, selector: "dbx-table-item-action" }, { kind: "component", type: DbxTableSummaryStartCellComponent, selector: "dbx-table-summary-start-cell" }, { kind: "component", type: DbxTableSummaryEndCellComponent, selector: "dbx-table-summary-end-cell" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
644
644
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxTableViewComponent, decorators: [{
|
|
645
645
|
type: Component,
|
|
646
646
|
args: [{ selector: 'dbx-table-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<dbx-loading [context]=\"context\">\n <dbx-loading class=\"dbx-table-view-loading\" [linear]=\"true\" [context]=\"dataLoadingContext\"></dbx-loading>\n <section class=\"dbx-table-view\" infinite-scroll [infiniteScrollDistance]=\"scrollDistance\" [infiniteScrollThrottle]=\"throttleScroll\" [scrollWindow]=\"false\" (scrolled)=\"onScrollDown()\">\n <table class=\"dbx-table-view-table\" mat-table [dataSource]=\"elements$\" [trackBy]=\"(trackByFunction$ | async) || DEFAULT_TRACK_BY_FUNCTION\">\n <!-- Header/Item column -->\n <ng-container [matColumnDef]=\"itemsColumnName\" [sticky]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-input-cell></dbx-table-input-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-header [element]=\"element\"></dbx-table-item-header>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-start-cell></dbx-table-summary-start-cell>\n </td>\n </ng-container>\n\n <!-- Column Definitions -->\n <ng-container [matColumnDef]=\"column.columnName\" [sticky]=\"false\" *ngFor=\"let column of innerColumns$ | async\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-column-header [column]=\"column\"></dbx-table-column-header>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-cell [element]=\"element\" [column]=\"column\"></dbx-table-item-cell>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-column-footer [column]=\"column\"></dbx-table-column-footer>\n </td>\n </ng-container>\n\n <!-- Tail/Action column -->\n <ng-container [matColumnDef]=\"actionsColumnName\" [stickyEnd]=\"true\">\n <th mat-header-cell *matHeaderCellDef>\n <dbx-table-action-cell></dbx-table-action-cell>\n </th>\n <td mat-cell *matCellDef=\"let element\">\n <dbx-table-item-action [element]=\"element\"></dbx-table-item-action>\n </td>\n <td mat-footer-cell *matFooterCellDef>\n <dbx-table-summary-end-cell></dbx-table-summary-end-cell>\n </td>\n </ng-container>\n\n <!-- Table View -->\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns$ | async\"></tr>\n\n <tr mat-footer-row *matFooterRowDef=\"displayedColumns$ | async; sticky: true\"></tr>\n </table>\n </section>\n</dbx-loading>\n" }]
|