@dereekb/dbx-web 8.13.7 → 8.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/extension/index.mjs +2 -1
- package/esm2020/lib/extension/widget/index.mjs +7 -0
- package/esm2020/lib/extension/widget/widget.component.mjs +54 -0
- package/esm2020/lib/extension/widget/widget.directive.mjs +17 -0
- package/esm2020/lib/extension/widget/widget.list.component.mjs +66 -0
- package/esm2020/lib/extension/widget/widget.mjs +2 -0
- package/esm2020/lib/extension/widget/widget.module.mjs +38 -0
- package/esm2020/lib/extension/widget/widget.service.mjs +45 -0
- package/esm2020/lib/layout/list/list.grid.view.component.mjs +60 -24
- package/esm2020/lib/layout/list/list.layout.module.mjs +6 -2
- package/fesm2015/dereekb-dbx-web.mjs +261 -25
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +255 -25
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/extension/index.d.ts +1 -0
- package/lib/extension/widget/index.d.ts +6 -0
- package/lib/extension/widget/widget.component.d.ts +20 -0
- package/lib/extension/widget/widget.d.ts +13 -0
- package/lib/extension/widget/widget.directive.d.ts +7 -0
- package/lib/extension/widget/widget.list.component.d.ts +21 -0
- package/lib/extension/widget/widget.module.d.ts +14 -0
- package/lib/extension/widget/widget.service.d.ts +32 -0
- package/lib/layout/list/list.grid.view.component.d.ts +26 -8
- package/lib/layout/list/list.layout.module.d.ts +1 -1
- package/package.json +5 -5
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
export * from './calendar';
|
|
2
|
-
|
|
2
|
+
export * from './widget';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jYWxlbmRhcic7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldCc7XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './widget';
|
|
2
|
+
export * from './widget.component';
|
|
3
|
+
export * from './widget.directive';
|
|
4
|
+
export * from './widget.list.component';
|
|
5
|
+
export * from './widget.module';
|
|
6
|
+
export * from './widget.service';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL3dpZGdldC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3dpZGdldCc7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0Lmxpc3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC5zZXJ2aWNlJztcbiJdfQ==
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { BehaviorSubject, map } from 'rxjs';
|
|
2
|
+
import { Component, Input } from '@angular/core';
|
|
3
|
+
import { DbxWidgetService } from './widget.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./widget.service";
|
|
6
|
+
import * as i2 from "@dereekb/dbx-core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
/**
|
|
9
|
+
* Used to display a corresponding widget based on the input data.
|
|
10
|
+
*/
|
|
11
|
+
export class DbxWidgetViewComponent {
|
|
12
|
+
constructor(dbxWidgetService) {
|
|
13
|
+
this.dbxWidgetService = dbxWidgetService;
|
|
14
|
+
this._config = new BehaviorSubject(undefined);
|
|
15
|
+
this.config$ = this._config.pipe(map((pair) => {
|
|
16
|
+
let config;
|
|
17
|
+
if (pair != null) {
|
|
18
|
+
const entry = this.dbxWidgetService.getWidgetEntry(pair.type);
|
|
19
|
+
if (entry) {
|
|
20
|
+
config = {
|
|
21
|
+
componentClass: entry.componentClass,
|
|
22
|
+
data: pair.data
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
return config;
|
|
27
|
+
}));
|
|
28
|
+
}
|
|
29
|
+
ngOnDestroy() {
|
|
30
|
+
this._config.complete();
|
|
31
|
+
}
|
|
32
|
+
set config(config) {
|
|
33
|
+
this._config.next(config);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
DbxWidgetViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetViewComponent, deps: [{ token: i1.DbxWidgetService }], target: i0.ɵɵFactoryTarget.Component });
|
|
37
|
+
DbxWidgetViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: DbxWidgetViewComponent, selector: "dbx-widget-view", inputs: { config: "config" }, host: { classAttribute: "dbx-widget-view" }, ngImport: i0, template: `
|
|
38
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
39
|
+
`, isInline: true, components: [{ type: i2.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], pipes: { "async": i3.AsyncPipe } });
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetViewComponent, decorators: [{
|
|
41
|
+
type: Component,
|
|
42
|
+
args: [{
|
|
43
|
+
selector: 'dbx-widget-view',
|
|
44
|
+
template: `
|
|
45
|
+
<dbx-injection [config]="config$ | async"></dbx-injection>
|
|
46
|
+
`,
|
|
47
|
+
host: {
|
|
48
|
+
class: 'dbx-widget-view'
|
|
49
|
+
}
|
|
50
|
+
}]
|
|
51
|
+
}], ctorParameters: function () { return [{ type: i1.DbxWidgetService }]; }, propDecorators: { config: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}] } });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vd2lkZ2V0L3dpZGdldC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLGVBQWUsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDeEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFJNUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7Ozs7O0FBRXBEOztHQUVHO0FBVUgsTUFBTSxPQUFPLHNCQUFzQjtJQXNCakMsWUFBcUIsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFyQi9DLFlBQU8sR0FBRyxJQUFJLGVBQWUsQ0FBMkIsU0FBUyxDQUFDLENBQUM7UUFFbEUsWUFBTyxHQUFtRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDbEYsR0FBRyxDQUFDLENBQUMsSUFBOEIsRUFBRSxFQUFFO1lBQ3JDLElBQUksTUFBMEMsQ0FBQztZQUUvQyxJQUFJLElBQUksSUFBSSxJQUFJLEVBQUU7Z0JBQ2hCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUU5RCxJQUFJLEtBQUssRUFBRTtvQkFDVCxNQUFNLEdBQUc7d0JBQ1AsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO3dCQUNwQyxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7cUJBQ2hCLENBQUM7aUJBQ0g7YUFDRjtZQUVELE9BQU8sTUFBTSxDQUFDO1FBQ2hCLENBQUMsQ0FBQyxDQUNILENBQUM7SUFFd0QsQ0FBQztJQUUzRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFDSSxNQUFNLENBQUMsTUFBZ0M7UUFDekMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDNUIsQ0FBQzs7bUhBL0JVLHNCQUFzQjt1R0FBdEIsc0JBQXNCLGtJQVB2Qjs7R0FFVDsyRkFLVSxzQkFBc0I7a0JBVGxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsUUFBUSxFQUFFOztHQUVUO29CQUNELElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsaUJBQWlCO3FCQUN6QjtpQkFDRjt1R0E4QkssTUFBTTtzQkFEVCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSwgQmVoYXZpb3JTdWJqZWN0LCBtYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudENvbmZpZyB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieFdpZGdldERhdGFQYWlyIH0gZnJvbSAnLi93aWRnZXQnO1xuaW1wb3J0IHsgRGJ4V2lkZ2V0U2VydmljZSB9IGZyb20gJy4vd2lkZ2V0LnNlcnZpY2UnO1xuXG4vKipcbiAqIFVzZWQgdG8gZGlzcGxheSBhIGNvcnJlc3BvbmRpbmcgd2lkZ2V0IGJhc2VkIG9uIHRoZSBpbnB1dCBkYXRhLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtd2lkZ2V0LXZpZXcnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkYngtaW5qZWN0aW9uIFtjb25maWddPVwiY29uZmlnJCB8IGFzeW5jXCI+PC9kYngtaW5qZWN0aW9uPlxuICBgLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdkYngtd2lkZ2V0LXZpZXcnXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgRGJ4V2lkZ2V0Vmlld0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgX2NvbmZpZyA9IG5ldyBCZWhhdmlvclN1YmplY3Q8TWF5YmU8RGJ4V2lkZ2V0RGF0YVBhaXI+Pih1bmRlZmluZWQpO1xuXG4gIHJlYWRvbmx5IGNvbmZpZyQ6IE9ic2VydmFibGU8TWF5YmU8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPj4gPSB0aGlzLl9jb25maWcucGlwZShcbiAgICBtYXAoKHBhaXI6IE1heWJlPERieFdpZGdldERhdGFQYWlyPikgPT4ge1xuICAgICAgbGV0IGNvbmZpZzogTWF5YmU8RGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnPjtcblxuICAgICAgaWYgKHBhaXIgIT0gbnVsbCkge1xuICAgICAgICBjb25zdCBlbnRyeSA9IHRoaXMuZGJ4V2lkZ2V0U2VydmljZS5nZXRXaWRnZXRFbnRyeShwYWlyLnR5cGUpO1xuXG4gICAgICAgIGlmIChlbnRyeSkge1xuICAgICAgICAgIGNvbmZpZyA9IHtcbiAgICAgICAgICAgIGNvbXBvbmVudENsYXNzOiBlbnRyeS5jb21wb25lbnRDbGFzcyxcbiAgICAgICAgICAgIGRhdGE6IHBhaXIuZGF0YVxuICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGNvbmZpZztcbiAgICB9KVxuICApO1xuXG4gIGNvbnN0cnVjdG9yKHJlYWRvbmx5IGRieFdpZGdldFNlcnZpY2U6IERieFdpZGdldFNlcnZpY2UpIHt9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5fY29uZmlnLmNvbXBsZXRlKCk7XG4gIH1cblxuICBASW5wdXQoKVxuICBzZXQgY29uZmlnKGNvbmZpZzogTWF5YmU8RGJ4V2lkZ2V0RGF0YVBhaXI+KSB7XG4gICAgdGhpcy5fY29uZmlnLm5leHQoY29uZmlnKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Directive, Inject } from '@angular/core';
|
|
2
|
+
import { DBX_INJECTION_COMPONENT_DATA } from '@dereekb/dbx-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class AbstractDbxWidgetComponent {
|
|
5
|
+
constructor(data) {
|
|
6
|
+
this.data = data;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
AbstractDbxWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AbstractDbxWidgetComponent, deps: [{ token: DBX_INJECTION_COMPONENT_DATA }], target: i0.ɵɵFactoryTarget.Directive });
|
|
10
|
+
AbstractDbxWidgetComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: AbstractDbxWidgetComponent, ngImport: i0 });
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AbstractDbxWidgetComponent, decorators: [{
|
|
12
|
+
type: Directive
|
|
13
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
14
|
+
type: Inject,
|
|
15
|
+
args: [DBX_INJECTION_COMPONENT_DATA]
|
|
16
|
+
}] }]; } });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vd2lkZ2V0L3dpZGdldC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBR2pFLE1BQU0sT0FBZ0IsMEJBQTBCO0lBQzlDLFlBQTJELElBQU87UUFBUCxTQUFJLEdBQUosSUFBSSxDQUFHO0lBQUcsQ0FBQzs7dUhBRGxELDBCQUEwQixrQkFDMUIsNEJBQTRCOzJHQUQ1QiwwQkFBMEI7MkZBQTFCLDBCQUEwQjtrQkFEL0MsU0FBUzs7MEJBRUssTUFBTTsyQkFBQyw0QkFBNEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgREJYX0lOSkVDVElPTl9DT01QT05FTlRfREFUQSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3REYnhXaWRnZXRDb21wb25lbnQ8VD4ge1xuICBjb25zdHJ1Y3RvcihASW5qZWN0KERCWF9JTkpFQ1RJT05fQ09NUE9ORU5UX0RBVEEpIHJlYWRvbmx5IGRhdGE6IFQpIHt9XG59XG4iXX0=
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { of } from 'rxjs';
|
|
3
|
+
import { AbstractDbxListWrapperDirective, DEFAULT_LIST_WRAPPER_DIRECTIVE_TEMPLATE, AbstractDbxValueListViewItemComponent, provideDbxListView, AbstractDbxListGridViewDirective, DEFAULT_DBX_VALUE_LIST_GRID_DIRECTIVE_TEMPLATE } from '../../layout/list';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../layout/list/list.component";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "../../layout/list/list.grid.view.component";
|
|
8
|
+
import * as i4 from "./widget.component";
|
|
9
|
+
/**
|
|
10
|
+
* Demo DbxSelectionListWrapperDirective
|
|
11
|
+
*/
|
|
12
|
+
export class DbxWidgetListGridComponent extends AbstractDbxListWrapperDirective {
|
|
13
|
+
constructor() {
|
|
14
|
+
super({
|
|
15
|
+
componentClass: DbxWidgetListGridViewComponent,
|
|
16
|
+
defaultSelectionMode: 'view'
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
DbxWidgetListGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetListGridComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
21
|
+
DbxWidgetListGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: DbxWidgetListGridComponent, selector: "dbx-widget-grid", usesInheritance: true, ngImport: i0, template: "\n<dbx-list [state$]=\"state$\" [config]=\"config$ | async\" [disabled]=\"disabled\" [selectionMode]=\"selectionMode\">\n <ng-content top select=\"[top]\"></ng-content>\n <ng-content bottom select=\"[bottom]\"></ng-content>\n <ng-content empty select=\"[empty]\"></ng-content>\n</dbx-list>\n", isInline: true, components: [{ type: i1.DbxListComponent, selector: "dbx-list", inputs: ["padded", "state$", "config", "disabled", "selectionMode"], outputs: ["contentScrolled"] }], pipes: { "async": i2.AsyncPipe } });
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetListGridComponent, decorators: [{
|
|
23
|
+
type: Component,
|
|
24
|
+
args: [{
|
|
25
|
+
selector: 'dbx-widget-grid',
|
|
26
|
+
template: DEFAULT_LIST_WRAPPER_DIRECTIVE_TEMPLATE
|
|
27
|
+
}]
|
|
28
|
+
}], ctorParameters: function () { return []; } });
|
|
29
|
+
export class DbxWidgetListGridViewComponent extends AbstractDbxListGridViewDirective {
|
|
30
|
+
constructor() {
|
|
31
|
+
super(...arguments);
|
|
32
|
+
this.config = {
|
|
33
|
+
grid: {
|
|
34
|
+
// TODO: Make configurable.
|
|
35
|
+
columns: 'repeat(auto-fill, minmax(120px, 1fr))',
|
|
36
|
+
gap: '8px'
|
|
37
|
+
},
|
|
38
|
+
componentClass: DbxWidgetListGridViewItemComponent,
|
|
39
|
+
mapValuesToItemValues: (x) => of(x.map((y) => ({ ...y, itemValue: y })))
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
DbxWidgetListGridViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetListGridViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
44
|
+
DbxWidgetListGridViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: DbxWidgetListGridViewComponent, selector: "ng-component", providers: provideDbxListView(DbxWidgetListGridViewComponent), usesInheritance: true, ngImport: i0, template: "<dbx-list-grid-view [config]=\"config\"></dbx-list-grid-view>", isInline: true, components: [{ type: i3.DbxValueListGridViewComponent, selector: "dbx-list-grid-view" }] });
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetListGridViewComponent, decorators: [{
|
|
46
|
+
type: Component,
|
|
47
|
+
args: [{
|
|
48
|
+
template: DEFAULT_DBX_VALUE_LIST_GRID_DIRECTIVE_TEMPLATE,
|
|
49
|
+
providers: provideDbxListView(DbxWidgetListGridViewComponent)
|
|
50
|
+
}]
|
|
51
|
+
}] });
|
|
52
|
+
export class DbxWidgetListGridViewItemComponent extends AbstractDbxValueListViewItemComponent {
|
|
53
|
+
}
|
|
54
|
+
DbxWidgetListGridViewItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetListGridViewItemComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
55
|
+
DbxWidgetListGridViewItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: DbxWidgetListGridViewItemComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: `
|
|
56
|
+
<dbx-widget-view [config]="itemValue"></dbx-widget-view>
|
|
57
|
+
`, isInline: true, components: [{ type: i4.DbxWidgetViewComponent, selector: "dbx-widget-view", inputs: ["config"] }] });
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetListGridViewItemComponent, decorators: [{
|
|
59
|
+
type: Component,
|
|
60
|
+
args: [{
|
|
61
|
+
template: `
|
|
62
|
+
<dbx-widget-view [config]="itemValue"></dbx-widget-view>
|
|
63
|
+
`
|
|
64
|
+
}]
|
|
65
|
+
}] });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0Lmxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi93aWRnZXQvd2lkZ2V0Lmxpc3QuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMxQixPQUFPLEVBQUUsK0JBQStCLEVBQUUsdUNBQXVDLEVBQThCLHFDQUFxQyxFQUFFLGtCQUFrQixFQUFzQixnQ0FBZ0MsRUFBRSw4Q0FBOEMsRUFBRSxNQUFNLG1CQUFtQixDQUFDOzs7Ozs7QUFLMVM7O0dBRUc7QUFLSCxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsK0JBQWtEO0lBQ2hHO1FBQ0UsS0FBSyxDQUFDO1lBQ0osY0FBYyxFQUFFLDhCQUE4QjtZQUM5QyxvQkFBb0IsRUFBRSxNQUFNO1NBQzdCLENBQUMsQ0FBQztJQUNMLENBQUM7O3VIQU5VLDBCQUEwQjsyR0FBMUIsMEJBQTBCOzJGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsUUFBUSxFQUFFLHVDQUF1QztpQkFDbEQ7O0FBY0QsTUFBTSxPQUFPLDhCQUErQixTQUFRLGdDQUFtRDtJQUp2Rzs7UUFLVyxXQUFNLEdBQStEO1lBQzVFLElBQUksRUFBRTtnQkFDSiwyQkFBMkI7Z0JBQzNCLE9BQU8sRUFBRSx1Q0FBdUM7Z0JBQ2hELEdBQUcsRUFBRSxLQUFLO2FBQ1g7WUFDRCxjQUFjLEVBQUUsa0NBQWtDO1lBQ2xELHFCQUFxQixFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLFNBQVMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7U0FDekUsQ0FBQztLQUNIOzsySEFWWSw4QkFBOEI7K0dBQTlCLDhCQUE4Qix1Q0FGOUIsa0JBQWtCLENBQUMsOEJBQThCLENBQUM7MkZBRWxELDhCQUE4QjtrQkFKMUMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsOENBQThDO29CQUN4RCxTQUFTLEVBQUUsa0JBQWtCLGdDQUFnQztpQkFDOUQ7O0FBa0JELE1BQU0sT0FBTyxrQ0FBbUMsU0FBUSxxQ0FBd0Q7OytIQUFuRyxrQ0FBa0M7bUhBQWxDLGtDQUFrQywyRUFKbkM7O0dBRVQ7MkZBRVUsa0NBQWtDO2tCQUw5QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRTs7R0FFVDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgb2YgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEFic3RyYWN0RGJ4TGlzdFdyYXBwZXJEaXJlY3RpdmUsIERFRkFVTFRfTElTVF9XUkFQUEVSX0RJUkVDVElWRV9URU1QTEFURSwgRGJ4VmFsdWVMaXN0R3JpZFZpZXdDb25maWcsIEFic3RyYWN0RGJ4VmFsdWVMaXN0Vmlld0l0ZW1Db21wb25lbnQsIHByb3ZpZGVEYnhMaXN0VmlldywgRGJ4VmFsdWVBc0xpc3RJdGVtLCBBYnN0cmFjdERieExpc3RHcmlkVmlld0RpcmVjdGl2ZSwgREVGQVVMVF9EQlhfVkFMVUVfTElTVF9HUklEX0RJUkVDVElWRV9URU1QTEFURSB9IGZyb20gJy4uLy4uL2xheW91dC9saXN0JztcbmltcG9ydCB7IERieFdpZGdldERhdGFQYWlyIH0gZnJvbSAnLi93aWRnZXQnO1xuXG5leHBvcnQgdHlwZSBEYnhXaWRnZXREYXRhUGFpcldpdGhTZWxlY3Rpb24gPSBEYnhWYWx1ZUFzTGlzdEl0ZW08RGJ4V2lkZ2V0RGF0YVBhaXI+O1xuXG4vKipcbiAqIERlbW8gRGJ4U2VsZWN0aW9uTGlzdFdyYXBwZXJEaXJlY3RpdmVcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGJ4LXdpZGdldC1ncmlkJyxcbiAgdGVtcGxhdGU6IERFRkFVTFRfTElTVF9XUkFQUEVSX0RJUkVDVElWRV9URU1QTEFURVxufSlcbmV4cG9ydCBjbGFzcyBEYnhXaWRnZXRMaXN0R3JpZENvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0RGJ4TGlzdFdyYXBwZXJEaXJlY3RpdmU8RGJ4V2lkZ2V0RGF0YVBhaXI+IHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoe1xuICAgICAgY29tcG9uZW50Q2xhc3M6IERieFdpZGdldExpc3RHcmlkVmlld0NvbXBvbmVudCxcbiAgICAgIGRlZmF1bHRTZWxlY3Rpb25Nb2RlOiAndmlldydcbiAgICB9KTtcbiAgfVxufVxuXG5AQ29tcG9uZW50KHtcbiAgdGVtcGxhdGU6IERFRkFVTFRfREJYX1ZBTFVFX0xJU1RfR1JJRF9ESVJFQ1RJVkVfVEVNUExBVEUsXG4gIHByb3ZpZGVyczogcHJvdmlkZURieExpc3RWaWV3KERieFdpZGdldExpc3RHcmlkVmlld0NvbXBvbmVudClcbn0pXG5leHBvcnQgY2xhc3MgRGJ4V2lkZ2V0TGlzdEdyaWRWaWV3Q29tcG9uZW50IGV4dGVuZHMgQWJzdHJhY3REYnhMaXN0R3JpZFZpZXdEaXJlY3RpdmU8RGJ4V2lkZ2V0RGF0YVBhaXI+IHtcbiAgcmVhZG9ubHkgY29uZmlnOiBEYnhWYWx1ZUxpc3RHcmlkVmlld0NvbmZpZzxEYnhXaWRnZXREYXRhUGFpcldpdGhTZWxlY3Rpb24+ID0ge1xuICAgIGdyaWQ6IHtcbiAgICAgIC8vIFRPRE86IE1ha2UgY29uZmlndXJhYmxlLlxuICAgICAgY29sdW1uczogJ3JlcGVhdChhdXRvLWZpbGwsIG1pbm1heCgxMjBweCwgMWZyKSknLFxuICAgICAgZ2FwOiAnOHB4J1xuICAgIH0sXG4gICAgY29tcG9uZW50Q2xhc3M6IERieFdpZGdldExpc3RHcmlkVmlld0l0ZW1Db21wb25lbnQsXG4gICAgbWFwVmFsdWVzVG9JdGVtVmFsdWVzOiAoeCkgPT4gb2YoeC5tYXAoKHkpID0+ICh7IC4uLnksIGl0ZW1WYWx1ZTogeSB9KSkpXG4gIH07XG59XG5cbkBDb21wb25lbnQoe1xuICB0ZW1wbGF0ZTogYFxuICAgIDxkYngtd2lkZ2V0LXZpZXcgW2NvbmZpZ109XCJpdGVtVmFsdWVcIj48L2RieC13aWRnZXQtdmlldz5cbiAgYFxufSlcbmV4cG9ydCBjbGFzcyBEYnhXaWRnZXRMaXN0R3JpZFZpZXdJdGVtQ29tcG9uZW50IGV4dGVuZHMgQWJzdHJhY3REYnhWYWx1ZUxpc3RWaWV3SXRlbUNvbXBvbmVudDxEYnhXaWRnZXREYXRhUGFpcj4ge31cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi93aWRnZXQvd2lkZ2V0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNb2RlbFR5cGVEYXRhUGFpciwgVHlwZWRNb2RlbCwgTWFwRnVuY3Rpb24sIFJlYWRLZXlGdW5jdGlvbiB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuXG4vKipcbiAqIFdpZGdldCB0eXBlIGlkZW50aWZpZXJcbiAqL1xuZXhwb3J0IHR5cGUgRGJ4V2lkZ2V0VHlwZSA9IHN0cmluZztcblxuLyoqXG4gKiBUeXBlIGFuZCBkYXRhIHBhaXIgZm9yIGEgRGJ4V2lkZ2V0LlxuICovXG5leHBvcnQgdHlwZSBEYnhXaWRnZXREYXRhUGFpcjxUID0gdW5rbm93bj4gPSBNb2RlbFR5cGVEYXRhUGFpcjxUPjtcblxuLyoqXG4gKiBVc2VkIGZvciBjb252ZXJ0aW5nIHRoZSBpbnB1dCBkYXRhIGludG8gYSBEYnhXaWRnZXREYXRhUGFpciB2YWx1ZS5cbiAqL1xuZXhwb3J0IHR5cGUgRGJ4V2lkZ2V0RGF0YVBhaXJGYWN0b3J5PFQ+ID0gTWFwRnVuY3Rpb248VCwgRGJ4V2lkZ2V0RGF0YVBhaXI8VD4+O1xuIl19
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { DbxInjectionComponentModule } from '@dereekb/dbx-core';
|
|
4
|
+
import { DbxListLayoutModule } from '../../layout/list/list.layout.module';
|
|
5
|
+
import { DbxWidgetViewComponent } from './widget.component';
|
|
6
|
+
import { DbxWidgetListGridComponent, DbxWidgetListGridViewComponent, DbxWidgetListGridViewItemComponent } from './widget.list.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
/**
|
|
9
|
+
* Contains components related to displaying "widgets" for pieces of data.
|
|
10
|
+
*/
|
|
11
|
+
export class DbxWidgetModule {
|
|
12
|
+
}
|
|
13
|
+
DbxWidgetModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
14
|
+
DbxWidgetModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetModule, declarations: [DbxWidgetViewComponent, DbxWidgetListGridComponent, DbxWidgetListGridViewComponent, DbxWidgetListGridViewItemComponent], imports: [
|
|
15
|
+
//
|
|
16
|
+
CommonModule,
|
|
17
|
+
DbxListLayoutModule,
|
|
18
|
+
DbxInjectionComponentModule], exports: [DbxWidgetViewComponent, DbxWidgetListGridComponent, DbxWidgetListGridViewComponent, DbxWidgetListGridViewItemComponent] });
|
|
19
|
+
DbxWidgetModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetModule, imports: [[
|
|
20
|
+
//
|
|
21
|
+
CommonModule,
|
|
22
|
+
DbxListLayoutModule,
|
|
23
|
+
DbxInjectionComponentModule
|
|
24
|
+
]] });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetModule, decorators: [{
|
|
26
|
+
type: NgModule,
|
|
27
|
+
args: [{
|
|
28
|
+
imports: [
|
|
29
|
+
//
|
|
30
|
+
CommonModule,
|
|
31
|
+
DbxListLayoutModule,
|
|
32
|
+
DbxInjectionComponentModule
|
|
33
|
+
],
|
|
34
|
+
declarations: [DbxWidgetViewComponent, DbxWidgetListGridComponent, DbxWidgetListGridViewComponent, DbxWidgetListGridViewItemComponent],
|
|
35
|
+
exports: [DbxWidgetViewComponent, DbxWidgetListGridComponent, DbxWidgetListGridViewComponent, DbxWidgetListGridViewItemComponent]
|
|
36
|
+
}]
|
|
37
|
+
}] });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vd2lkZ2V0L3dpZGdldC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDaEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDNUQsT0FBTyxFQUFFLDBCQUEwQixFQUFFLDhCQUE4QixFQUFFLGtDQUFrQyxFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBRXpJOztHQUVHO0FBV0gsTUFBTSxPQUFPLGVBQWU7OzRHQUFmLGVBQWU7NkdBQWYsZUFBZSxpQkFIWCxzQkFBc0IsRUFBRSwwQkFBMEIsRUFBRSw4QkFBOEIsRUFBRSxrQ0FBa0M7UUFMbkksRUFBRTtRQUNGLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsMkJBQTJCLGFBR25CLHNCQUFzQixFQUFFLDBCQUEwQixFQUFFLDhCQUE4QixFQUFFLGtDQUFrQzs2R0FFckgsZUFBZSxZQVRqQjtZQUNQLEVBQUU7WUFDRixZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLDJCQUEyQjtTQUM1QjsyRkFJVSxlQUFlO2tCQVYzQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxFQUFFO3dCQUNGLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQiwyQkFBMkI7cUJBQzVCO29CQUNELFlBQVksRUFBRSxDQUFDLHNCQUFzQixFQUFFLDBCQUEwQixFQUFFLDhCQUE4QixFQUFFLGtDQUFrQyxDQUFDO29CQUN0SSxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSwwQkFBMEIsRUFBRSw4QkFBOEIsRUFBRSxrQ0FBa0MsQ0FBQztpQkFDbEkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudE1vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieExpc3RMYXlvdXRNb2R1bGUgfSBmcm9tICcuLi8uLi9sYXlvdXQvbGlzdC9saXN0LmxheW91dC5tb2R1bGUnO1xuaW1wb3J0IHsgRGJ4V2lkZ2V0Vmlld0NvbXBvbmVudCB9IGZyb20gJy4vd2lkZ2V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhXaWRnZXRMaXN0R3JpZENvbXBvbmVudCwgRGJ4V2lkZ2V0TGlzdEdyaWRWaWV3Q29tcG9uZW50LCBEYnhXaWRnZXRMaXN0R3JpZFZpZXdJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi93aWRnZXQubGlzdC5jb21wb25lbnQnO1xuXG4vKipcbiAqIENvbnRhaW5zIGNvbXBvbmVudHMgcmVsYXRlZCB0byBkaXNwbGF5aW5nIFwid2lkZ2V0c1wiIGZvciBwaWVjZXMgb2YgZGF0YS5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIC8vXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIERieExpc3RMYXlvdXRNb2R1bGUsXG4gICAgRGJ4SW5qZWN0aW9uQ29tcG9uZW50TW9kdWxlXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW0RieFdpZGdldFZpZXdDb21wb25lbnQsIERieFdpZGdldExpc3RHcmlkQ29tcG9uZW50LCBEYnhXaWRnZXRMaXN0R3JpZFZpZXdDb21wb25lbnQsIERieFdpZGdldExpc3RHcmlkVmlld0l0ZW1Db21wb25lbnRdLFxuICBleHBvcnRzOiBbRGJ4V2lkZ2V0Vmlld0NvbXBvbmVudCwgRGJ4V2lkZ2V0TGlzdEdyaWRDb21wb25lbnQsIERieFdpZGdldExpc3RHcmlkVmlld0NvbXBvbmVudCwgRGJ4V2lkZ2V0TGlzdEdyaWRWaWV3SXRlbUNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgRGJ4V2lkZ2V0TW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { filterMaybeValues, mapIterable } from '@dereekb/util';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* Service used to register widgets.
|
|
6
|
+
*/
|
|
7
|
+
export class DbxWidgetService {
|
|
8
|
+
constructor() {
|
|
9
|
+
this._entries = new Map();
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Used to register an entry. If an entry with the same type is already registered, this will override it by default.
|
|
13
|
+
*
|
|
14
|
+
* @param entry
|
|
15
|
+
* @param override
|
|
16
|
+
*/
|
|
17
|
+
register(entry, override = true) {
|
|
18
|
+
if (override || !this._entries.has(entry.type)) {
|
|
19
|
+
this._entries.set(entry.type, entry);
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
// MARK: Get
|
|
27
|
+
getWidgetIdentifiers() {
|
|
28
|
+
return Array.from(this._entries.keys());
|
|
29
|
+
}
|
|
30
|
+
getWidgetEntry(type) {
|
|
31
|
+
return this._entries.get(type);
|
|
32
|
+
}
|
|
33
|
+
getWidgetEntries(types) {
|
|
34
|
+
return filterMaybeValues(mapIterable(types ?? [], (x) => this._entries.get(x)));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
DbxWidgetService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
38
|
+
DbxWidgetService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetService, providedIn: 'root' });
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxWidgetService, decorators: [{
|
|
40
|
+
type: Injectable,
|
|
41
|
+
args: [{
|
|
42
|
+
providedIn: 'root'
|
|
43
|
+
}]
|
|
44
|
+
}] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL3dpZGdldC93aWRnZXQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVUsVUFBVSxFQUFrQixNQUFNLGVBQWUsQ0FBQztBQUNuRSxPQUFPLEVBQVMsaUJBQWlCLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWN0RTs7R0FFRztBQUlILE1BQU0sT0FBTyxnQkFBZ0I7SUFIN0I7UUFJVSxhQUFRLEdBQUcsSUFBSSxHQUFHLEVBQWlDLENBQUM7S0E2QjdEO0lBM0JDOzs7OztPQUtHO0lBQ0gsUUFBUSxDQUFDLEtBQXFCLEVBQUUsV0FBb0IsSUFBSTtRQUN0RCxJQUFJLFFBQVEsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUM5QyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3JDLE9BQU8sSUFBSSxDQUFDO1NBQ2I7YUFBTTtZQUNMLE9BQU8sS0FBSyxDQUFDO1NBQ2Q7SUFDSCxDQUFDO0lBRUQsWUFBWTtJQUNaLG9CQUFvQjtRQUNsQixPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRCxjQUFjLENBQUMsSUFBbUI7UUFDaEMsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsS0FBOEI7UUFDN0MsT0FBTyxpQkFBaUIsQ0FBQyxXQUFXLENBQUMsS0FBSyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2xGLENBQUM7OzZHQTdCVSxnQkFBZ0I7aUhBQWhCLGdCQUFnQixjQUZmLE1BQU07MkZBRVAsZ0JBQWdCO2tCQUg1QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgT3B0aW9uYWwsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1heWJlLCBmaWx0ZXJNYXliZVZhbHVlcywgbWFwSXRlcmFibGUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IERieFdpZGdldFR5cGUgfSBmcm9tICcuL3dpZGdldCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4V2lkZ2V0RW50cnkge1xuICAvKipcbiAgICogV2lkZ2V0IHR5cGUgdG8gcmVzcG9uZCB0by5cbiAgICovXG4gIHJlYWRvbmx5IHR5cGU6IERieFdpZGdldFR5cGU7XG4gIC8qKlxuICAgKiBXaWRnZXQgY29tcG9uZW50IGNsYXNzIHRvIHVzZS5cbiAgICovXG4gIHJlYWRvbmx5IGNvbXBvbmVudENsYXNzOiBUeXBlPHVua25vd24+O1xufVxuXG4vKipcbiAqIFNlcnZpY2UgdXNlZCB0byByZWdpc3RlciB3aWRnZXRzLlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEYnhXaWRnZXRTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBfZW50cmllcyA9IG5ldyBNYXA8RGJ4V2lkZ2V0VHlwZSwgRGJ4V2lkZ2V0RW50cnk+KCk7XG5cbiAgLyoqXG4gICAqIFVzZWQgdG8gcmVnaXN0ZXIgYW4gZW50cnkuIElmIGFuIGVudHJ5IHdpdGggdGhlIHNhbWUgdHlwZSBpcyBhbHJlYWR5IHJlZ2lzdGVyZWQsIHRoaXMgd2lsbCBvdmVycmlkZSBpdCBieSBkZWZhdWx0LlxuICAgKlxuICAgKiBAcGFyYW0gZW50cnlcbiAgICogQHBhcmFtIG92ZXJyaWRlXG4gICAqL1xuICByZWdpc3RlcihlbnRyeTogRGJ4V2lkZ2V0RW50cnksIG92ZXJyaWRlOiBib29sZWFuID0gdHJ1ZSk6IGJvb2xlYW4ge1xuICAgIGlmIChvdmVycmlkZSB8fCAhdGhpcy5fZW50cmllcy5oYXMoZW50cnkudHlwZSkpIHtcbiAgICAgIHRoaXMuX2VudHJpZXMuc2V0KGVudHJ5LnR5cGUsIGVudHJ5KTtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgLy8gTUFSSzogR2V0XG4gIGdldFdpZGdldElkZW50aWZpZXJzKCk6IERieFdpZGdldFR5cGVbXSB7XG4gICAgcmV0dXJuIEFycmF5LmZyb20odGhpcy5fZW50cmllcy5rZXlzKCkpO1xuICB9XG5cbiAgZ2V0V2lkZ2V0RW50cnkodHlwZTogRGJ4V2lkZ2V0VHlwZSk6IE1heWJlPERieFdpZGdldEVudHJ5PiB7XG4gICAgcmV0dXJuIHRoaXMuX2VudHJpZXMuZ2V0KHR5cGUpO1xuICB9XG5cbiAgZ2V0V2lkZ2V0RW50cmllcyh0eXBlczogSXRlcmFibGU8RGJ4V2lkZ2V0VHlwZT4pOiBEYnhXaWRnZXRFbnRyeVtdIHtcbiAgICByZXR1cm4gZmlsdGVyTWF5YmVWYWx1ZXMobWFwSXRlcmFibGUodHlwZXMgPz8gW10sICh4KSA9PiB0aGlzLl9lbnRyaWVzLmdldCh4KSkpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,14 +1,16 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { shareReplay, map } from 'rxjs';
|
|
1
|
+
import { Component, Directive, Input, Optional } from '@angular/core';
|
|
2
|
+
import { shareReplay, map, BehaviorSubject, combineLatest, of } from 'rxjs';
|
|
3
3
|
import { AbstractDbxValueListViewDirective } from './list.view.value.directive';
|
|
4
4
|
import { mergeObjects } from '@dereekb/util';
|
|
5
5
|
import { DbxValueListItemViewComponent } from './list.view.value.component';
|
|
6
|
+
import { DbxListView } from './list.view';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/common";
|
|
8
|
-
import * as i2 from "
|
|
9
|
-
import * as i3 from "
|
|
10
|
-
import * as i4 from "@
|
|
11
|
-
import * as i5 from "@angular/
|
|
9
|
+
import * as i2 from "./list.view";
|
|
10
|
+
import * as i3 from "../../router/layout/anchor/anchor.component";
|
|
11
|
+
import * as i4 from "@dereekb/dbx-core";
|
|
12
|
+
import * as i5 from "@angular/flex-layout/grid";
|
|
13
|
+
import * as i6 from "@angular/material/core";
|
|
12
14
|
/**
|
|
13
15
|
* Renders a grid view using input configuration. Requires a parent DbxListView.
|
|
14
16
|
*/
|
|
@@ -37,40 +39,72 @@ export const DEFAULT_LIST_GRID_SIZE_CONFIG = {
|
|
|
37
39
|
gap: '8px'
|
|
38
40
|
};
|
|
39
41
|
/**
|
|
40
|
-
*
|
|
42
|
+
* Optional parent directive used to control grid size.
|
|
41
43
|
*/
|
|
42
|
-
export class
|
|
44
|
+
export class DbxValueListGridSizeDirective {
|
|
43
45
|
constructor() {
|
|
44
|
-
|
|
45
|
-
this.
|
|
46
|
+
this._gridSize = new BehaviorSubject(undefined);
|
|
47
|
+
this.gridSize$ = this._gridSize.asObservable();
|
|
46
48
|
}
|
|
47
|
-
get
|
|
48
|
-
return this.
|
|
49
|
+
get gridSize() {
|
|
50
|
+
return this._gridSize.value;
|
|
49
51
|
}
|
|
50
|
-
set
|
|
51
|
-
|
|
52
|
+
set gridSize(gridSize) {
|
|
53
|
+
if (gridSize) {
|
|
54
|
+
this._gridSize.next(gridSize);
|
|
55
|
+
}
|
|
52
56
|
}
|
|
53
|
-
|
|
54
|
-
|
|
57
|
+
ngOnDestroy() {
|
|
58
|
+
this._gridSize.complete();
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
DbxValueListGridSizeDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxValueListGridSizeDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
62
|
+
DbxValueListGridSizeDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: DbxValueListGridSizeDirective, selector: "[dbxListGridSize]", inputs: { gridSize: ["dbxListGridSize", "gridSize"] }, ngImport: i0 });
|
|
63
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxValueListGridSizeDirective, decorators: [{
|
|
64
|
+
type: Directive,
|
|
65
|
+
args: [{
|
|
66
|
+
selector: '[dbxListGridSize]'
|
|
67
|
+
}]
|
|
68
|
+
}], propDecorators: { gridSize: [{
|
|
69
|
+
type: Input,
|
|
70
|
+
args: ['dbxListGridSize']
|
|
71
|
+
}] } });
|
|
72
|
+
/**
|
|
73
|
+
* Content view for a DbxValueListGridView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.
|
|
74
|
+
*/
|
|
75
|
+
export class DbxValueListGridItemViewComponent extends DbxValueListItemViewComponent {
|
|
76
|
+
constructor(dbxListView, _gridSizeOverride) {
|
|
77
|
+
super(dbxListView);
|
|
78
|
+
this._gridSizeOverride = _gridSizeOverride;
|
|
79
|
+
this._defaultGrid = new BehaviorSubject(undefined);
|
|
80
|
+
this.grid$ = combineLatest([this._defaultGrid, this._gridSizeOverride?.gridSize$ ?? of(undefined)]).pipe(map(([defaultGrid, overrideGrid]) => {
|
|
81
|
+
const grid = mergeObjects([DEFAULT_LIST_GRID_SIZE_CONFIG, defaultGrid, overrideGrid]);
|
|
82
|
+
return grid;
|
|
83
|
+
}), shareReplay(1));
|
|
84
|
+
this.gap$ = this.grid$.pipe(map((x) => x.gap));
|
|
85
|
+
this.columns$ = this.grid$.pipe(map((x) => x.columns));
|
|
86
|
+
}
|
|
87
|
+
set grid(grid) {
|
|
88
|
+
this._defaultGrid.next(grid);
|
|
55
89
|
}
|
|
56
|
-
|
|
57
|
-
|
|
90
|
+
ngOnDestroy() {
|
|
91
|
+
this._defaultGrid.complete();
|
|
58
92
|
}
|
|
59
93
|
}
|
|
60
|
-
DbxValueListGridItemViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxValueListGridItemViewComponent, deps:
|
|
94
|
+
DbxValueListGridItemViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxValueListGridItemViewComponent, deps: [{ token: i2.DbxListView }, { token: DbxValueListGridSizeDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
61
95
|
DbxValueListGridItemViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: DbxValueListGridItemViewComponent, selector: "dbx-list-grid-view-content", inputs: { grid: "grid" }, host: { classAttribute: "dbx-list-grid-view" }, usesInheritance: true, ngImport: i0, template: `
|
|
62
|
-
<div [gdGap]="gap" [gdColumns]="columns">
|
|
96
|
+
<div [gdGap]="gap$ | async" [gdColumns]="columns$ | async">
|
|
63
97
|
<dbx-anchor *ngFor="let item of items" matRipple [matRippleDisabled]="rippleDisabledOnItem(item)" class="dbx-list-grid-view-item" [anchor]="item.anchor" [disabled]="item.disabled" (click)="onClickItem(item)">
|
|
64
98
|
<div dbx-injection [config]="item.config"></div>
|
|
65
99
|
</dbx-anchor>
|
|
66
100
|
</div>
|
|
67
|
-
`, isInline: true, components: [{ type:
|
|
101
|
+
`, isInline: true, components: [{ type: i3.DbxAnchorComponent, selector: "dbx-anchor, [dbx-anchor]", inputs: ["block"] }, { type: i4.DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], directives: [{ type: i5.DefaultGridGapDirective, selector: " [gdGap], [gdGap.xs], [gdGap.sm], [gdGap.md], [gdGap.lg], [gdGap.xl], [gdGap.lt-sm], [gdGap.lt-md], [gdGap.lt-lg], [gdGap.lt-xl], [gdGap.gt-xs], [gdGap.gt-sm], [gdGap.gt-md], [gdGap.gt-lg]", inputs: ["gdGap", "gdGap.xs", "gdGap.sm", "gdGap.md", "gdGap.lg", "gdGap.xl", "gdGap.lt-sm", "gdGap.lt-md", "gdGap.lt-lg", "gdGap.lt-xl", "gdGap.gt-xs", "gdGap.gt-sm", "gdGap.gt-md", "gdGap.gt-lg"] }, { type: i5.DefaultGridColumnsDirective, selector: " [gdColumns], [gdColumns.xs], [gdColumns.sm], [gdColumns.md], [gdColumns.lg], [gdColumns.xl], [gdColumns.lt-sm], [gdColumns.lt-md], [gdColumns.lt-lg], [gdColumns.lt-xl], [gdColumns.gt-xs], [gdColumns.gt-sm], [gdColumns.gt-md], [gdColumns.gt-lg]", inputs: ["gdColumns", "gdColumns.xs", "gdColumns.sm", "gdColumns.md", "gdColumns.lg", "gdColumns.xl", "gdColumns.lt-sm", "gdColumns.lt-md", "gdColumns.lt-lg", "gdColumns.lt-xl", "gdColumns.gt-xs", "gdColumns.gt-sm", "gdColumns.gt-md", "gdColumns.gt-lg"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }], pipes: { "async": i1.AsyncPipe } });
|
|
68
102
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DbxValueListGridItemViewComponent, decorators: [{
|
|
69
103
|
type: Component,
|
|
70
104
|
args: [{
|
|
71
105
|
selector: 'dbx-list-grid-view-content',
|
|
72
106
|
template: `
|
|
73
|
-
<div [gdGap]="gap" [gdColumns]="columns">
|
|
107
|
+
<div [gdGap]="gap$ | async" [gdColumns]="columns$ | async">
|
|
74
108
|
<dbx-anchor *ngFor="let item of items" matRipple [matRippleDisabled]="rippleDisabledOnItem(item)" class="dbx-list-grid-view-item" [anchor]="item.anchor" [disabled]="item.disabled" (click)="onClickItem(item)">
|
|
75
109
|
<div dbx-injection [config]="item.config"></div>
|
|
76
110
|
</dbx-anchor>
|
|
@@ -80,7 +114,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
80
114
|
class: 'dbx-list-grid-view'
|
|
81
115
|
}
|
|
82
116
|
}]
|
|
83
|
-
}],
|
|
117
|
+
}], ctorParameters: function () { return [{ type: i2.DbxListView }, { type: DbxValueListGridSizeDirective, decorators: [{
|
|
118
|
+
type: Optional
|
|
119
|
+
}] }]; }, propDecorators: { grid: [{
|
|
84
120
|
type: Input
|
|
85
121
|
}] } });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.grid.view.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/layout/list/list.grid.view.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAa,QAAQ,EAAE,MAAM,eAAe,CAAC;AACjF,OAAO,EAAE,WAAW,EAAE,GAAG,EAAE,eAAe,EAAE,aAAa,EAAE,EAAE,EAAc,MAAM,MAAM,CAAC;AAExF,OAAO,EAAE,iCAAiC,EAAE,MAAM,6BAA6B,CAAC;AAChF,OAAO,EAAS,YAAY,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,6BAA6B,EAA0B,MAAM,6BAA6B,CAAC;AACpG,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;;;;;;;;AAM1C;;GAEG;AAOH,MAAM,OAAO,6BAAwL,SAAQ,iCAA6C;IAN1P;;QAOW,UAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAC9C,mBAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACzC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,EAC3B,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;KACH;;0HANY,6BAA6B;8GAA7B,6BAA6B,iFAJ9B;;GAET,0EAuEU,iCAAiC;2FArEjC,6BAA6B;kBANzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,QAAQ,EAAE;;GAET;iBACF;;AAsBD,MAAM,CAAC,MAAM,6BAA6B,GAA2C;IACnF,OAAO,EAAE,uCAAuC;IAChD,GAAG,EAAE,KAAK;CACX,CAAC;AAEF;;GAEG;AAIH,MAAM,OAAO,6BAA6B;IAH1C;QAIU,cAAS,GAAG,IAAI,eAAe,CAAyD,SAAS,CAAC,CAAC;QAElG,cAAS,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;KAgBpD;IAdC,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;IAC9B,CAAC;IAED,IAAI,QAAQ,CAAC,QAAgE;QAC3E,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;;0HAlBU,6BAA6B;8GAA7B,6BAA6B;2FAA7B,6BAA6B;kBAHzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,mBAAmB;iBAC9B;8BAOK,QAAQ;sBADX,KAAK;uBAAC,iBAAiB;;AAgB1B;;GAEG;AAcH,MAAM,OAAO,iCAA0F,SAAQ,6BAAmC;IAchJ,YAAY,WAA2B,EAAsB,iBAAiD;QAC5G,KAAK,CAAC,WAAW,CAAC,CAAC;QADwC,sBAAiB,GAAjB,iBAAiB,CAAgC;QAbtG,iBAAY,GAAG,IAAI,eAAe,CAAyD,SAAS,CAAC,CAAC;QAErG,UAAK,GAAuD,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAC9J,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,YAAY,CAAC,EAAE,EAAE;YAClC,MAAM,IAAI,GAAG,YAAY,CAAyC,CAAC,6BAA6B,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC,CAAC;YAC9H,OAAO,IAA8C,CAAC;QACxD,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,SAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC1C,aAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IAI3D,CAAC;IAED,IACI,IAAI,CAAC,IAA4D;QACnE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;;8HAzBU,iCAAiC,6CAcqC,6BAA6B;kHAdnG,iCAAiC,mKAXlC;;;;;;GAMT;2FAKU,iCAAiC;kBAb7C,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,QAAQ,EAAE;;;;;;GAMT;oBACD,IAAI,EAAE;wBACJ,KAAK,EAAE,oBAAoB;qBAC5B;iBACF;oFAekF,6BAA6B;0BAApE,QAAQ;4CAK9C,IAAI;sBADP,KAAK","sourcesContent":["import { Component, Directive, Input, OnDestroy, Optional } from '@angular/core';\nimport { shareReplay, map, BehaviorSubject, combineLatest, of, Observable } from 'rxjs';\nimport { DbxValueListItem } from './list.view.value';\nimport { AbstractDbxValueListViewDirective } from './list.view.value.directive';\nimport { Maybe, mergeObjects } from '@dereekb/util';\nimport { DbxValueListItemViewComponent, DbxValueListViewConfig } from './list.view.value.component';\nimport { DbxListView } from './list.view';\n\nexport interface DbxValueListGridViewConfig<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown> extends DbxValueListViewConfig<T, I, V> {\n  grid?: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>;\n}\n\n/**\n * Renders a grid view using input configuration. Requires a parent DbxListView.\n */\n@Component({\n  selector: 'dbx-list-grid-view',\n  template: `\n    <dbx-list-grid-view-content [grid]=\"grid$ | async\" [items]=\"items$ | async\" [emitAllClicks]=\"emitAllClicks$ | async\"></dbx-list-grid-view-content>\n  `\n})\nexport class DbxValueListGridViewComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>, V = unknown, C extends DbxValueListGridViewConfig<T, I, V> = DbxValueListGridViewConfig<T, I, V>> extends AbstractDbxValueListViewDirective<T, I, V, C> {\n  readonly grid$ = this.config$.pipe(map((x) => x.grid));\n  readonly emitAllClicks$ = this.config$.pipe(\n    map((x) => x.emitAllClicks),\n    shareReplay(1)\n  );\n}\n\nexport interface DbxValueListGridItemViewGridSizeConfig {\n  /**\n   * Gap size in %, px, vw, vh\n   */\n  gap: string;\n  /**\n   * Columns configuration.\n   *\n   * Example: repeat(auto-fill, minmax(200px, 1fr))\n   */\n  columns: string;\n}\n\nexport const DEFAULT_LIST_GRID_SIZE_CONFIG: DbxValueListGridItemViewGridSizeConfig = {\n  columns: 'repeat(auto-fill, minmax(320px, 1fr))',\n  gap: '8px'\n};\n\n/**\n * Optional parent directive used to control grid size.\n */\n@Directive({\n  selector: '[dbxListGridSize]'\n})\nexport class DbxValueListGridSizeDirective implements OnDestroy {\n  private _gridSize = new BehaviorSubject<Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>>(undefined);\n\n  readonly gridSize$ = this._gridSize.asObservable();\n\n  @Input('dbxListGridSize')\n  get gridSize(): Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>> {\n    return this._gridSize.value;\n  }\n\n  set gridSize(gridSize: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>) {\n    if (gridSize) {\n      this._gridSize.next(gridSize);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._gridSize.complete();\n  }\n}\n\n/**\n * Content view for a DbxValueListGridView. It can be used directly in cases where the items are already configured, or want to be configured in a non-standard fashion.\n */\n@Component({\n  selector: 'dbx-list-grid-view-content',\n  template: `\n    <div [gdGap]=\"gap$ | async\" [gdColumns]=\"columns$ | async\">\n      <dbx-anchor *ngFor=\"let item of items\" matRipple [matRippleDisabled]=\"rippleDisabledOnItem(item)\" class=\"dbx-list-grid-view-item\" [anchor]=\"item.anchor\" [disabled]=\"item.disabled\" (click)=\"onClickItem(item)\">\n        <div dbx-injection [config]=\"item.config\"></div>\n      </dbx-anchor>\n    </div>\n  `,\n  host: {\n    class: 'dbx-list-grid-view'\n  }\n})\nexport class DbxValueListGridItemViewComponent<T, I extends DbxValueListItem<T> = DbxValueListItem<T>> extends DbxValueListItemViewComponent<T, I> implements OnDestroy {\n  private _defaultGrid = new BehaviorSubject<Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>>(undefined);\n\n  readonly grid$: Observable<DbxValueListGridItemViewGridSizeConfig> = combineLatest([this._defaultGrid, this._gridSizeOverride?.gridSize$ ?? of(undefined)]).pipe(\n    map(([defaultGrid, overrideGrid]) => {\n      const grid = mergeObjects<DbxValueListGridItemViewGridSizeConfig>([DEFAULT_LIST_GRID_SIZE_CONFIG, defaultGrid, overrideGrid]);\n      return grid as DbxValueListGridItemViewGridSizeConfig;\n    }),\n    shareReplay(1)\n  );\n\n  readonly gap$ = this.grid$.pipe(map((x) => x.gap));\n  readonly columns$ = this.grid$.pipe(map((x) => x.columns));\n\n  constructor(dbxListView: DbxListView<T>, @Optional() private _gridSizeOverride?: DbxValueListGridSizeDirective) {\n    super(dbxListView);\n  }\n\n  @Input()\n  set grid(grid: Maybe<Partial<DbxValueListGridItemViewGridSizeConfig>>) {\n    this._defaultGrid.next(grid);\n  }\n\n  ngOnDestroy(): void {\n    this._defaultGrid.complete();\n  }\n}\n"]}
|
|
@@ -13,7 +13,7 @@ import { DbxSelectionValueListItemViewComponent, DbxSelectionValueListViewCompon
|
|
|
13
13
|
import { DbxValueListItemViewComponent, DbxValueListViewComponent } from './list.view.value.component';
|
|
14
14
|
import { DbxValueListItemModifierDirective } from './list.view.value.modifier.directive';
|
|
15
15
|
import { DbxListItemDisableRippleModifierDirective } from './list.view.value.modifier.ripple.directive';
|
|
16
|
-
import { DbxValueListGridItemViewComponent, DbxValueListGridViewComponent } from './list.grid.view.component';
|
|
16
|
+
import { DbxValueListGridItemViewComponent, DbxValueListGridSizeDirective, DbxValueListGridViewComponent } from './list.grid.view.component';
|
|
17
17
|
import { FlexLayoutModule } from '@angular/flex-layout';
|
|
18
18
|
import * as i0 from "@angular/core";
|
|
19
19
|
export class DbxListLayoutModule {
|
|
@@ -26,6 +26,7 @@ DbxListLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", ver
|
|
|
26
26
|
DbxListEmptyContentComponent,
|
|
27
27
|
DbxValueListViewComponent,
|
|
28
28
|
DbxValueListItemViewComponent,
|
|
29
|
+
DbxValueListGridSizeDirective,
|
|
29
30
|
DbxValueListGridViewComponent,
|
|
30
31
|
DbxValueListGridItemViewComponent,
|
|
31
32
|
DbxSelectionValueListViewComponent,
|
|
@@ -37,6 +38,7 @@ DbxListLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", ver
|
|
|
37
38
|
DbxListEmptyContentComponent,
|
|
38
39
|
DbxValueListViewComponent,
|
|
39
40
|
DbxValueListItemViewComponent,
|
|
41
|
+
DbxValueListGridSizeDirective,
|
|
40
42
|
DbxValueListGridViewComponent,
|
|
41
43
|
DbxValueListGridItemViewComponent,
|
|
42
44
|
DbxSelectionValueListViewComponent,
|
|
@@ -55,6 +57,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
55
57
|
DbxListEmptyContentComponent,
|
|
56
58
|
DbxValueListViewComponent,
|
|
57
59
|
DbxValueListItemViewComponent,
|
|
60
|
+
DbxValueListGridSizeDirective,
|
|
58
61
|
DbxValueListGridViewComponent,
|
|
59
62
|
DbxValueListGridItemViewComponent,
|
|
60
63
|
DbxSelectionValueListViewComponent,
|
|
@@ -68,6 +71,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
68
71
|
DbxListEmptyContentComponent,
|
|
69
72
|
DbxValueListViewComponent,
|
|
70
73
|
DbxValueListItemViewComponent,
|
|
74
|
+
DbxValueListGridSizeDirective,
|
|
71
75
|
DbxValueListGridViewComponent,
|
|
72
76
|
DbxValueListGridItemViewComponent,
|
|
73
77
|
DbxSelectionValueListViewComponent,
|
|
@@ -77,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
77
81
|
]
|
|
78
82
|
}]
|
|
79
83
|
}] });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5sYXlvdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2xheW91dC9saXN0L2xpc3QubGF5b3V0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNyRixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUNuSSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUseUJBQXlCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN2RyxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN6RixPQUFPLEVBQUUseUNBQXlDLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN4RyxPQUFPLEVBQUUsaUNBQWlDLEVBQUUsNkJBQTZCLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3SSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFrQ3hELE1BQU0sT0FBTyxtQkFBbUI7O2dIQUFuQixtQkFBbUI7aUhBQW5CLG1CQUFtQjtRQTdCNUIsRUFBRTtRQUNGLGdCQUFnQjtRQUNoQiwrQkFBK0I7UUFDL0IsNEJBQTRCO1FBQzVCLHlCQUF5QjtRQUN6Qiw2QkFBNkI7UUFDN0IsNkJBQTZCO1FBQzdCLDZCQUE2QjtRQUM3QixpQ0FBaUM7UUFDakMsa0NBQWtDO1FBQ2xDLHNDQUFzQztRQUN0QyxpQ0FBaUM7UUFDakMseUNBQXlDLGFBZGpDLFlBQVksRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUscUJBQXFCLEVBQUUsb0JBQW9CLEVBQUUsMkJBQTJCLEVBQUUsYUFBYSxFQUFFLGFBQWE7UUFpQmpMLEVBQUU7UUFDRixnQkFBZ0I7UUFDaEIsNEJBQTRCO1FBQzVCLHlCQUF5QjtRQUN6Qiw2QkFBNkI7UUFDN0IsNkJBQTZCO1FBQzdCLDZCQUE2QjtRQUM3QixpQ0FBaUM7UUFDakMsa0NBQWtDO1FBQ2xDLHNDQUFzQztRQUN0QyxpQ0FBaUM7UUFDakMseUNBQXlDO2lIQUdoQyxtQkFBbUIsWUEvQnJCLENBQUMsWUFBWSxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSwyQkFBMkIsRUFBRSxhQUFhLEVBQUUsYUFBYSxDQUFDOzJGQStCekssbUJBQW1CO2tCQWhDL0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLHFCQUFxQixFQUFFLG9CQUFvQixFQUFFLDJCQUEyQixFQUFFLGFBQWEsRUFBRSxhQUFhLENBQUM7b0JBQ3BMLFlBQVksRUFBRTt3QkFDWixFQUFFO3dCQUNGLGdCQUFnQjt3QkFDaEIsK0JBQStCO3dCQUMvQiw0QkFBNEI7d0JBQzVCLHlCQUF5Qjt3QkFDekIsNkJBQTZCO3dCQUM3Qiw2QkFBNkI7d0JBQzdCLDZCQUE2Qjt3QkFDN0IsaUNBQWlDO3dCQUNqQyxrQ0FBa0M7d0JBQ2xDLHNDQUFzQzt3QkFDdEMsaUNBQWlDO3dCQUNqQyx5Q0FBeUM7cUJBQzFDO29CQUNELE9BQU8sRUFBRTt3QkFDUCxFQUFFO3dCQUNGLGdCQUFnQjt3QkFDaEIsNEJBQTRCO3dCQUM1Qix5QkFBeUI7d0JBQ3pCLDZCQUE2Qjt3QkFDN0IsNkJBQTZCO3dCQUM3Qiw2QkFBNkI7d0JBQzdCLGlDQUFpQzt3QkFDakMsa0NBQWtDO3dCQUNsQyxzQ0FBc0M7d0JBQ3RDLGlDQUFpQzt3QkFDakMseUNBQXlDO3FCQUMxQztpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hdFJpcHBsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Um91dGVyQW5jaG9yTW9kdWxlIH0gZnJvbSAnLi4vLi4vcm91dGVyL2xheW91dC9hbmNob3IvYW5jaG9yLm1vZHVsZSc7XG5pbXBvcnQgeyBEYnhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnLi4vLi4vbG9hZGluZy9sb2FkaW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRMaXN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGlzdCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieEluamVjdGlvbkNvbXBvbmVudE1vZHVsZSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieExpc3RDb21wb25lbnQsIERieExpc3RJbnRlcm5hbENvbnRlbnREaXJlY3RpdmUgfSBmcm9tICcuL2xpc3QuY29tcG9uZW50JztcbmltcG9ydCB7IERieExpc3RFbXB0eUNvbnRlbnRDb21wb25lbnQgfSBmcm9tICcuL2xpc3QuY29udGVudC5lbXB0eS5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5maW5pdGVTY3JvbGxNb2R1bGUgfSBmcm9tICduZ3gtaW5maW5pdGUtc2Nyb2xsJztcbmltcG9ydCB7IERieFNlbGVjdGlvblZhbHVlTGlzdEl0ZW1WaWV3Q29tcG9uZW50LCBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9saXN0LnZpZXcudmFsdWUuc2VsZWN0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhWYWx1ZUxpc3RJdGVtVmlld0NvbXBvbmVudCwgRGJ4VmFsdWVMaXN0Vmlld0NvbXBvbmVudCB9IGZyb20gJy4vbGlzdC52aWV3LnZhbHVlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYnhWYWx1ZUxpc3RJdGVtTW9kaWZpZXJEaXJlY3RpdmUgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4TGlzdEl0ZW1EaXNhYmxlUmlwcGxlTW9kaWZpZXJEaXJlY3RpdmUgfSBmcm9tICcuL2xpc3Qudmlldy52YWx1ZS5tb2RpZmllci5yaXBwbGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieFZhbHVlTGlzdEdyaWRJdGVtVmlld0NvbXBvbmVudCwgRGJ4VmFsdWVMaXN0R3JpZFNpemVEaXJlY3RpdmUsIERieFZhbHVlTGlzdEdyaWRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9saXN0LmdyaWQudmlldy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmxleExheW91dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTWF0UmlwcGxlTW9kdWxlLCBGbGV4TGF5b3V0TW9kdWxlLCBEYnhMb2FkaW5nTW9kdWxlLCBEYnhSb3V0ZXJBbmNob3JNb2R1bGUsIEluZmluaXRlU2Nyb2xsTW9kdWxlLCBEYnhJbmplY3Rpb25Db21wb25lbnRNb2R1bGUsIE1hdExpc3RNb2R1bGUsIE1hdEljb25Nb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICAvL1xuICAgIERieExpc3RDb21wb25lbnQsXG4gICAgRGJ4TGlzdEludGVybmFsQ29udGVudERpcmVjdGl2ZSxcbiAgICBEYnhMaXN0RW1wdHlDb250ZW50Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdFZpZXdDb21wb25lbnQsXG4gICAgRGJ4VmFsdWVMaXN0SXRlbVZpZXdDb21wb25lbnQsXG4gICAgRGJ4VmFsdWVMaXN0R3JpZFNpemVEaXJlY3RpdmUsXG4gICAgRGJ4VmFsdWVMaXN0R3JpZFZpZXdDb21wb25lbnQsXG4gICAgRGJ4VmFsdWVMaXN0R3JpZEl0ZW1WaWV3Q29tcG9uZW50LFxuICAgIERieFNlbGVjdGlvblZhbHVlTGlzdFZpZXdDb21wb25lbnQsXG4gICAgRGJ4U2VsZWN0aW9uVmFsdWVMaXN0SXRlbVZpZXdDb21wb25lbnQsXG4gICAgRGJ4VmFsdWVMaXN0SXRlbU1vZGlmaWVyRGlyZWN0aXZlLFxuICAgIERieExpc3RJdGVtRGlzYWJsZVJpcHBsZU1vZGlmaWVyRGlyZWN0aXZlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICAvL1xuICAgIERieExpc3RDb21wb25lbnQsXG4gICAgRGJ4TGlzdEVtcHR5Q29udGVudENvbXBvbmVudCxcbiAgICBEYnhWYWx1ZUxpc3RWaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEl0ZW1WaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEdyaWRTaXplRGlyZWN0aXZlLFxuICAgIERieFZhbHVlTGlzdEdyaWRWaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEdyaWRJdGVtVmlld0NvbXBvbmVudCxcbiAgICBEYnhTZWxlY3Rpb25WYWx1ZUxpc3RWaWV3Q29tcG9uZW50LFxuICAgIERieFNlbGVjdGlvblZhbHVlTGlzdEl0ZW1WaWV3Q29tcG9uZW50LFxuICAgIERieFZhbHVlTGlzdEl0ZW1Nb2RpZmllckRpcmVjdGl2ZSxcbiAgICBEYnhMaXN0SXRlbURpc2FibGVSaXBwbGVNb2RpZmllckRpcmVjdGl2ZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIERieExpc3RMYXlvdXRNb2R1bGUge31cbiJdfQ==
|