@dereekb/dbx-web 9.24.17 → 9.24.19
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/dbx-web.module.mjs +1 -17
- package/esm2020/lib/extension/index.mjs +4 -1
- package/esm2020/lib/extension/structure/index.mjs +4 -0
- package/esm2020/lib/extension/structure/structure.body.directive.mjs +28 -0
- package/esm2020/lib/extension/structure/structure.module.mjs +27 -0
- package/esm2020/lib/extension/structure/structure.structure.directive.mjs +23 -0
- package/esm2020/lib/interaction/filter/filter.popover.button.directive.mjs +1 -1
- package/esm2020/lib/interaction/filter/filter.popover.component.mjs +17 -9
- package/esm2020/lib/interaction/filter/filter.preset.mjs +9 -4
- package/esm2020/mapbox/lib/mapbox.store.mjs +23 -3
- package/fesm2015/dereekb-dbx-web-mapbox.mjs +22 -2
- package/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/fesm2015/dereekb-dbx-web.mjs +129 -62
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web-mapbox.mjs +22 -2
- package/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +124 -57
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/dbx-web.module.d.ts +0 -10
- package/lib/extension/index.d.ts +1 -0
- package/lib/extension/structure/index.d.ts +3 -0
- package/lib/extension/structure/structure.body.directive.d.ts +9 -0
- package/lib/extension/structure/structure.module.d.ts +9 -0
- package/lib/extension/structure/structure.structure.directive.d.ts +15 -0
- package/lib/interaction/filter/filter.popover.button.directive.d.ts +4 -1
- package/lib/interaction/filter/filter.popover.component.d.ts +12 -4
- package/lib/interaction/filter/filter.preset.d.ts +3 -2
- package/mapbox/esm2020/lib/mapbox.store.mjs +23 -3
- package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs +22 -2
- package/mapbox/fesm2015/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs +22 -2
- package/mapbox/fesm2020/dereekb-dbx-web-mapbox.mjs.map +1 -1
- package/mapbox/lib/mapbox.store.d.ts +14 -0
- package/mapbox/package.json +3 -3
- package/package.json +3 -3
- 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.19",
|
|
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.19"
|
|
12
12
|
},
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"tslib": "^2.3.0"
|
|
@@ -14,20 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
14
14
|
exports: [DbxButtonModule, DbxActionModule, DbxLoadingModule]
|
|
15
15
|
}]
|
|
16
16
|
}] });
|
|
17
|
-
|
|
18
|
-
* Should only be imported once in the root app.
|
|
19
|
-
*
|
|
20
|
-
* Pre-configures the following modules:
|
|
21
|
-
*/
|
|
22
|
-
export class DbxWebRootModule {
|
|
23
|
-
}
|
|
24
|
-
DbxWebRootModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxWebRootModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
25
|
-
DbxWebRootModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: DbxWebRootModule });
|
|
26
|
-
DbxWebRootModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxWebRootModule });
|
|
27
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxWebRootModule, decorators: [{
|
|
28
|
-
type: NgModule,
|
|
29
|
-
args: [{
|
|
30
|
-
imports: []
|
|
31
|
-
}]
|
|
32
|
-
}] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGJ4LXdlYi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZGJ4LXdlYi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxZQUFZOzswR0FBWixZQUFZOzJHQUFaLFlBQVksWUFGYixlQUFlLEVBQUUsZUFBZSxFQUFFLGdCQUFnQjsyR0FFakQsWUFBWSxZQUZiLGVBQWUsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCOzRGQUVqRCxZQUFZO2tCQUh4QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGVBQWUsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLENBQUM7aUJBQzlEOztBQUdEOzs7O0dBSUc7QUFJSCxNQUFNLE9BQU8sZ0JBQWdCOzs4R0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQjs0RkFBaEIsZ0JBQWdCO2tCQUg1QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxFQUFFO2lCQUNaIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGJ4TG9hZGluZ01vZHVsZSB9IGZyb20gJy4vbG9hZGluZy9sb2FkaW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4QnV0dG9uTW9kdWxlIH0gZnJvbSAnLi9idXR0b24nO1xuaW1wb3J0IHsgRGJ4QWN0aW9uTW9kdWxlIH0gZnJvbSAnLi9hY3Rpb24nO1xuXG5ATmdNb2R1bGUoe1xuICBleHBvcnRzOiBbRGJ4QnV0dG9uTW9kdWxlLCBEYnhBY3Rpb25Nb2R1bGUsIERieExvYWRpbmdNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIERieFdlYk1vZHVsZSB7fVxuXG4vKipcbiAqIFNob3VsZCBvbmx5IGJlIGltcG9ydGVkIG9uY2UgaW4gdGhlIHJvb3QgYXBwLlxuICpcbiAqIFByZS1jb25maWd1cmVzIHRoZSBmb2xsb3dpbmcgbW9kdWxlczpcbiAqL1xuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW11cbn0pXG5leHBvcnQgY2xhc3MgRGJ4V2ViUm9vdE1vZHVsZSB7fVxuIl19
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGJ4LXdlYi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZGJ4LXdlYi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxZQUFZOzswR0FBWixZQUFZOzJHQUFaLFlBQVksWUFGYixlQUFlLEVBQUUsZUFBZSxFQUFFLGdCQUFnQjsyR0FFakQsWUFBWSxZQUZiLGVBQWUsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCOzRGQUVqRCxZQUFZO2tCQUh4QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGVBQWUsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLENBQUM7aUJBQzlEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGJ4TG9hZGluZ01vZHVsZSB9IGZyb20gJy4vbG9hZGluZy9sb2FkaW5nLm1vZHVsZSc7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4QnV0dG9uTW9kdWxlIH0gZnJvbSAnLi9idXR0b24nO1xuaW1wb3J0IHsgRGJ4QWN0aW9uTW9kdWxlIH0gZnJvbSAnLi9hY3Rpb24nO1xuXG5ATmdNb2R1bGUoe1xuICBleHBvcnRzOiBbRGJ4QnV0dG9uTW9kdWxlLCBEYnhBY3Rpb25Nb2R1bGUsIERieExvYWRpbmdNb2R1bGVdXG59KVxuZXhwb3J0IGNsYXNzIERieFdlYk1vZHVsZSB7fVxuIl19
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
// export * from './calendar';
|
|
1
2
|
export * from './model';
|
|
3
|
+
export * from './structure';
|
|
4
|
+
// export * from './table'; // nothing to export
|
|
2
5
|
export * from './widget';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDhCQUE4QjtBQUM5QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLGFBQWEsQ0FBQztBQUM1QixnREFBZ0Q7QUFDaEQsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBleHBvcnQgKiBmcm9tICcuL2NhbGVuZGFyJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9zdHJ1Y3R1cmUnO1xuLy8gZXhwb3J0ICogZnJvbSAnLi90YWJsZSc7IC8vIG5vdGhpbmcgdG8gZXhwb3J0XG5leHBvcnQgKiBmcm9tICcuL3dpZGdldCc7XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './structure.body.directive';
|
|
2
|
+
export * from './structure.module';
|
|
3
|
+
export * from './structure.structure.directive';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL3N0cnVjdHVyZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3RydWN0dXJlLmJvZHkuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vc3RydWN0dXJlLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3N0cnVjdHVyZS5zdHJ1Y3R1cmUuZGlyZWN0aXZlJztcbiJdfQ==
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import { DbxStructureDirective } from './structure.structure.directive';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* DbxStructureDirective used specifically on the body of the app.
|
|
6
|
+
*/
|
|
7
|
+
export class DbxBodyDirective extends DbxStructureDirective {
|
|
8
|
+
}
|
|
9
|
+
DbxBodyDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxBodyDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
10
|
+
DbxBodyDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: DbxBodyDirective, selector: "dbxBody,[dbxBody]", providers: [
|
|
11
|
+
{
|
|
12
|
+
provide: DbxStructureDirective,
|
|
13
|
+
useExisting: DbxBodyDirective
|
|
14
|
+
}
|
|
15
|
+
], usesInheritance: true, ngImport: i0 });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxBodyDirective, decorators: [{
|
|
17
|
+
type: Directive,
|
|
18
|
+
args: [{
|
|
19
|
+
selector: 'dbxBody,[dbxBody]',
|
|
20
|
+
providers: [
|
|
21
|
+
{
|
|
22
|
+
provide: DbxStructureDirective,
|
|
23
|
+
useExisting: DbxBodyDirective
|
|
24
|
+
}
|
|
25
|
+
]
|
|
26
|
+
}]
|
|
27
|
+
}] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlLmJvZHkuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LXdlYi9zcmMvbGliL2V4dGVuc2lvbi9zdHJ1Y3R1cmUvc3RydWN0dXJlLmJvZHkuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBYSxTQUFTLEVBQW9CLE1BQU0sZUFBZSxDQUFDO0FBR3ZFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQUV4RTs7R0FFRztBQVVILE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxxQkFBcUI7OzhHQUE5QyxnQkFBZ0I7a0dBQWhCLGdCQUFnQiw0Q0FQaEI7UUFDVDtZQUNFLE9BQU8sRUFBRSxxQkFBcUI7WUFDOUIsV0FBVyxFQUFFLGdCQUFnQjtTQUM5QjtLQUNGOzRGQUVVLGdCQUFnQjtrQkFUNUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLHFCQUFxQjs0QkFDOUIsV0FBVyxrQkFBa0I7eUJBQzlCO3FCQUNGO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSwgQmVoYXZpb3JTdWJqZWN0LCBtYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENvbXBvbmVudCwgRGlyZWN0aXZlLCBJbnB1dCwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRGJ4SW5qZWN0aW9uQ29tcG9uZW50Q29uZmlnIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuaW1wb3J0IHsgRGJ4U3RydWN0dXJlRGlyZWN0aXZlIH0gZnJvbSAnLi9zdHJ1Y3R1cmUuc3RydWN0dXJlLmRpcmVjdGl2ZSc7XG5cbi8qKlxuICogRGJ4U3RydWN0dXJlRGlyZWN0aXZlIHVzZWQgc3BlY2lmaWNhbGx5IG9uIHRoZSBib2R5IG9mIHRoZSBhcHAuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2RieEJvZHksW2RieEJvZHldJyxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogRGJ4U3RydWN0dXJlRGlyZWN0aXZlLFxuICAgICAgdXNlRXhpc3Rpbmc6IERieEJvZHlEaXJlY3RpdmVcbiAgICB9XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRGJ4Qm9keURpcmVjdGl2ZSBleHRlbmRzIERieFN0cnVjdHVyZURpcmVjdGl2ZSB7fVxuIl19
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { DbxStructureDirective } from './structure.structure.directive';
|
|
4
|
+
import { DbxBodyDirective } from './structure.body.directive';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const declarations = [DbxBodyDirective, DbxStructureDirective];
|
|
7
|
+
export class DbxStructureModule {
|
|
8
|
+
}
|
|
9
|
+
DbxStructureModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxStructureModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
DbxStructureModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: DbxStructureModule, declarations: [DbxBodyDirective, DbxStructureDirective], imports: [
|
|
11
|
+
//
|
|
12
|
+
CommonModule], exports: [DbxBodyDirective, DbxStructureDirective] });
|
|
13
|
+
DbxStructureModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxStructureModule, imports: [
|
|
14
|
+
//
|
|
15
|
+
CommonModule] });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxStructureModule, decorators: [{
|
|
17
|
+
type: NgModule,
|
|
18
|
+
args: [{
|
|
19
|
+
imports: [
|
|
20
|
+
//
|
|
21
|
+
CommonModule
|
|
22
|
+
],
|
|
23
|
+
declarations,
|
|
24
|
+
exports: declarations
|
|
25
|
+
}]
|
|
26
|
+
}] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9leHRlbnNpb24vc3RydWN0dXJlL3N0cnVjdHVyZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDeEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7O0FBRTlELE1BQU0sWUFBWSxHQUFHLENBQUMsZ0JBQWdCLEVBQUUscUJBQXFCLENBQUMsQ0FBQztBQVUvRCxNQUFNLE9BQU8sa0JBQWtCOztnSEFBbEIsa0JBQWtCO2lIQUFsQixrQkFBa0IsaUJBVlQsZ0JBQWdCLEVBQUUscUJBQXFCO1FBSXpELEVBQUU7UUFDRixZQUFZLGFBTE0sZ0JBQWdCLEVBQUUscUJBQXFCO2lIQVVoRCxrQkFBa0I7UUFOM0IsRUFBRTtRQUNGLFlBQVk7NEZBS0gsa0JBQWtCO2tCQVI5QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxFQUFFO3dCQUNGLFlBQVk7cUJBQ2I7b0JBQ0QsWUFBWTtvQkFDWixPQUFPLEVBQUUsWUFBWTtpQkFDdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERieFN0cnVjdHVyZURpcmVjdGl2ZSB9IGZyb20gJy4vc3RydWN0dXJlLnN0cnVjdHVyZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRGJ4Qm9keURpcmVjdGl2ZSB9IGZyb20gJy4vc3RydWN0dXJlLmJvZHkuZGlyZWN0aXZlJztcblxuY29uc3QgZGVjbGFyYXRpb25zID0gW0RieEJvZHlEaXJlY3RpdmUsIERieFN0cnVjdHVyZURpcmVjdGl2ZV07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICAvL1xuICAgIENvbW1vbk1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnMsXG4gIGV4cG9ydHM6IGRlY2xhcmF0aW9uc1xufSlcbmV4cG9ydCBjbGFzcyBEYnhTdHJ1Y3R1cmVNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Directive, ElementRef, Injector } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Used to reference a cdRef, injector, and element at the given element.
|
|
5
|
+
*
|
|
6
|
+
* Generally used for child views to reference a well-placed parent view.
|
|
7
|
+
*/
|
|
8
|
+
export class DbxStructureDirective {
|
|
9
|
+
constructor(cdRef, injector, element) {
|
|
10
|
+
this.cdRef = cdRef;
|
|
11
|
+
this.injector = injector;
|
|
12
|
+
this.element = element;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
DbxStructureDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxStructureDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
16
|
+
DbxStructureDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: DbxStructureDirective, selector: "[dbxStructure]", ngImport: i0 });
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxStructureDirective, decorators: [{
|
|
18
|
+
type: Directive,
|
|
19
|
+
args: [{
|
|
20
|
+
selector: '[dbxStructure]'
|
|
21
|
+
}]
|
|
22
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i0.ElementRef }]; } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlLnN0cnVjdHVyZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvZXh0ZW5zaW9uL3N0cnVjdHVyZS9zdHJ1Y3R1cmUuc3RydWN0dXJlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQWEsU0FBUyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQW9CLE1BQU0sZUFBZSxDQUFDOztBQUVoSDs7OztHQUlHO0FBSUgsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxZQUFxQixLQUF3QixFQUFXLFFBQWtCLEVBQVcsT0FBbUI7UUFBbkYsVUFBSyxHQUFMLEtBQUssQ0FBbUI7UUFBVyxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQVcsWUFBTyxHQUFQLE9BQU8sQ0FBWTtJQUFHLENBQUM7O21IQURqRyxxQkFBcUI7dUdBQXJCLHFCQUFxQjs0RkFBckIscUJBQXFCO2tCQUhqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxnQkFBZ0I7aUJBQzNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbmplY3RvciwgSW5wdXQsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFVzZWQgdG8gcmVmZXJlbmNlIGEgY2RSZWYsIGluamVjdG9yLCBhbmQgZWxlbWVudCBhdCB0aGUgZ2l2ZW4gZWxlbWVudC5cbiAqXG4gKiBHZW5lcmFsbHkgdXNlZCBmb3IgY2hpbGQgdmlld3MgdG8gcmVmZXJlbmNlIGEgd2VsbC1wbGFjZWQgcGFyZW50IHZpZXcuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tkYnhTdHJ1Y3R1cmVdJ1xufSlcbmV4cG9ydCBjbGFzcyBEYnhTdHJ1Y3R1cmVEaXJlY3RpdmUge1xuICBjb25zdHJ1Y3RvcihyZWFkb25seSBjZFJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYsIHJlYWRvbmx5IGluamVjdG9yOiBJbmplY3RvciwgcmVhZG9ubHkgZWxlbWVudDogRWxlbWVudFJlZikge31cbn1cbiJdfQ==
|
|
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
30
30
|
}], ctorParameters: function () { return [{ type: i1.DbxPopoverService }]; }, propDecorators: { config: [{
|
|
31
31
|
type: Input
|
|
32
32
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnBvcG92ZXIuYnV0dG9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9maWx0ZXIvZmlsdGVyLnBvcG92ZXIuYnV0dG9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUseUJBQXlCLEVBQTRCLE1BQU0sNEJBQTRCLENBQUM7QUFDakcsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7OztBQVF4RixNQUFNLE9BQWdCLG9DQUF1RCxTQUFRLDJCQUE2QztJQUloSSxZQUE2QixZQUErQjtRQUMxRCxLQUFLLEVBQUUsQ0FBQztRQURtQixpQkFBWSxHQUFaLFlBQVksQ0FBbUI7SUFFNUQsQ0FBQztJQUVrQixlQUFlLENBQUMsTUFBbUI7UUFDcEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUUzQixJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsTUFBTSxJQUFJLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1NBQ2hEO2FBQU0sSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNsQixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7U0FDcEM7UUFFRCxPQUFPLHlCQUF5QixDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQzlELE1BQU07WUFDTixHQUFHLE1BQU07U0FDVixDQUFDLENBQUM7SUFDTCxDQUFDOztrSUFyQm1CLG9DQUFvQztzSEFBcEMsb0NBQW9DOzRGQUFwQyxvQ0FBb0M7a0JBRHpELFNBQVM7d0dBR1IsTUFBTTtzQkFETCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgRGJ4UG9wb3ZlclNlcnZpY2UgfSBmcm9tICcuLi9wb3BvdmVyL3BvcG92ZXIuc2VydmljZSc7XG5pbXBvcnQgeyBEYnhGaWx0ZXJQb3BvdmVyQ29tcG9uZW50LCBEYnhGaWx0ZXJDb21wb25lbnRQYXJhbXMgfSBmcm9tICcuL2ZpbHRlci5wb3BvdmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBYnN0cmFjdFBvcG92ZXJSZWZEaXJlY3RpdmUgfSBmcm9tICcuLi9wb3BvdmVyL2Fic3RyYWN0LnBvcG92ZXIucmVmLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBGaWx0ZXJTb3VyY2UsIFByZXNldEZpbHRlclNvdXJjZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuXG5leHBvcnQgdHlwZSBEYnhGaWx0ZXJCdXR0b25Db25maWc8RiBleHRlbmRzIG9iamVjdD4gPSBEYnhGaWx0ZXJDb21wb25lbnRQYXJhbXM8Rj47XG5leHBvcnQgdHlwZSBEYnhGaWx0ZXJCdXR0b25Db25maWdXaXRoQ3VzdG9tRmlsdGVyPEYgZXh0ZW5kcyBvYmplY3QsIENGIGV4dGVuZHMgRmlsdGVyU291cmNlPEY+ID0gRmlsdGVyU291cmNlPEY+PiA9IE9taXQ8RGJ4RmlsdGVyQ29tcG9uZW50UGFyYW1zPEYsIGFueSwgQ0YsIGFueT4sICdwcmVzZXRGaWx0ZXInIHwgJ3ByZXNldEZpbHRlckNvbXBvbmVudENvbmZpZyc+O1xuZXhwb3J0IHR5cGUgRGJ4RmlsdGVyQnV0dG9uQ29uZmlnV2l0aFByZXNldEZpbHRlcjxGIGV4dGVuZHMgb2JqZWN0LCBQRiBleHRlbmRzIFByZXNldEZpbHRlclNvdXJjZTxGLCBhbnk+ID0gUHJlc2V0RmlsdGVyU291cmNlPEYsIGFueT4+ID0gT21pdDxEYnhGaWx0ZXJDb21wb25lbnRQYXJhbXM8RiwgYW55LCBhbnksIFBGPiwgJ2N1c3RvbUZpbHRlcicgfCAnY3VzdG9tRmlsdGVyQ29tcG9uZW50Q29uZmlnJz47XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0RmlsdGVyUG9wb3ZlckJ1dHRvbkRpcmVjdGl2ZTxGIGV4dGVuZHMgb2JqZWN0PiBleHRlbmRzIEFic3RyYWN0UG9wb3ZlclJlZkRpcmVjdGl2ZTx1bmtub3duLCB1bmtub3duPiB7XG4gIEBJbnB1dCgpXG4gIGNvbmZpZz86IERieEZpbHRlckNvbXBvbmVudFBhcmFtczxGLCBhbnksIGFueSwgYW55PjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHBvcHVwU2VydmljZTogRGJ4UG9wb3ZlclNlcnZpY2UpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIF9tYWtlUG9wb3ZlclJlZihvcmlnaW4/OiBFbGVtZW50UmVmKTogTmdQb3BvdmVyUmVmPHVua25vd24sIHVua25vd24+IHtcbiAgICBjb25zdCBjb25maWcgPSB0aGlzLmNvbmZpZztcblxuICAgIGlmICghY29uZmlnKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ01pc3NpbmcgZmlsdGVyQnV0dG9uQ29uZmlnLicpO1xuICAgIH0gZWxzZSBpZiAoIW9yaWdpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIG9yaWdpbi4nKTtcbiAgICB9XG5cbiAgICByZXR1cm4gRGJ4RmlsdGVyUG9wb3ZlckNvbXBvbmVudC5vcGVuUG9wb3Zlcih0aGlzLnBvcHVwU2VydmljZSwge1xuICAgICAgb3JpZ2luLFxuICAgICAgLi4uY29uZmlnXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -27,15 +27,19 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
27
27
|
this._showPreset = new BehaviorSubject(false);
|
|
28
28
|
this.showPreset$ = this._showPreset.asObservable();
|
|
29
29
|
this.config$ = this._showPreset.pipe(map((showPreset) => {
|
|
30
|
-
const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass } = this.config;
|
|
30
|
+
const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;
|
|
31
31
|
let componentClass;
|
|
32
|
+
let baseConfig;
|
|
32
33
|
if (showPreset) {
|
|
33
|
-
componentClass = presetFilterComponentClass;
|
|
34
|
+
componentClass = (presetFilterComponentConfig?.componentClass ?? presetFilterComponentClass);
|
|
35
|
+
baseConfig = presetFilterComponentConfig;
|
|
34
36
|
}
|
|
35
37
|
else {
|
|
36
|
-
componentClass = customFilterComponentClass;
|
|
38
|
+
componentClass = (customFilterComponentConfig?.componentClass ?? customFilterComponentClass);
|
|
39
|
+
baseConfig = customFilterComponentConfig;
|
|
37
40
|
}
|
|
38
41
|
const config = {
|
|
42
|
+
...baseConfig,
|
|
39
43
|
componentClass,
|
|
40
44
|
init: (filterSource) => {
|
|
41
45
|
connector.connectWithSource(filterSource);
|
|
@@ -47,12 +51,14 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
47
51
|
this.close();
|
|
48
52
|
});
|
|
49
53
|
}
|
|
54
|
+
// run the next init if provided
|
|
55
|
+
baseConfig?.init?.(filterSource);
|
|
50
56
|
}
|
|
51
57
|
};
|
|
52
58
|
return config;
|
|
53
59
|
}));
|
|
54
60
|
}
|
|
55
|
-
static openPopover(popupService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, connector, initialFilterObs, closeOnFilterChange, customizeButtonText, showCloseButton, closeButtonText }, popoverKey) {
|
|
61
|
+
static openPopover(popupService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig, connector, initialFilterObs, closeOnFilterChange, customizeButtonText, showCloseButton, closeButtonText }, popoverKey) {
|
|
56
62
|
return popupService.open({
|
|
57
63
|
key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,
|
|
58
64
|
origin,
|
|
@@ -68,6 +74,8 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
68
74
|
closeButtonText,
|
|
69
75
|
customFilterComponentClass,
|
|
70
76
|
presetFilterComponentClass,
|
|
77
|
+
customFilterComponentConfig,
|
|
78
|
+
presetFilterComponentConfig,
|
|
71
79
|
connector,
|
|
72
80
|
initialFilterObs,
|
|
73
81
|
closeOnFilterChange
|
|
@@ -85,14 +93,14 @@ export class DbxFilterPopoverComponent extends AbstractPopoverDirective {
|
|
|
85
93
|
}
|
|
86
94
|
ngOnInit() {
|
|
87
95
|
let showPreset = false;
|
|
88
|
-
const { customFilterComponentClass, presetFilterComponentClass } = this.config;
|
|
89
|
-
if (customFilterComponentClass) {
|
|
96
|
+
const { customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;
|
|
97
|
+
if (customFilterComponentClass || customFilterComponentConfig) {
|
|
90
98
|
showPreset = false;
|
|
91
99
|
}
|
|
92
|
-
if (presetFilterComponentClass) {
|
|
100
|
+
if (presetFilterComponentClass || presetFilterComponentConfig) {
|
|
93
101
|
showPreset = true;
|
|
94
102
|
}
|
|
95
|
-
if (!customFilterComponentClass && !presetFilterComponentClass) {
|
|
103
|
+
if (!(customFilterComponentClass || customFilterComponentConfig) && !(presetFilterComponentClass || presetFilterComponentConfig)) {
|
|
96
104
|
throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');
|
|
97
105
|
}
|
|
98
106
|
this._showPreset.next(showPreset);
|
|
@@ -114,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
114
122
|
type: Component,
|
|
115
123
|
args: [{ template: "<dbx-popover-content>\n <!-- Header -->\n <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n <ng-container *ngIf=\"showSwitchButtons\" [ngSwitch]=\"showPreset$ | async\">\n <button *ngSwitchCase=\"true\" mat-flat-button color=\"accent\" (click)=\"showCustom()\">{{ customizeButtonText }}</button>\n <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n </ng-container>\n <ng-container *ngIf=\"showCloseButton\">\n <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</button>\n </ng-container>\n </dbx-popover-header>\n <!-- Content -->\n <dbx-popover-scroll-content>\n <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n </dbx-popover-scroll-content>\n</dbx-popover-content>\n" }]
|
|
116
124
|
}], ctorParameters: function () { return [{ type: i1.DbxPopoverComponent }]; } });
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.ts","../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Component, ElementRef, Type, OnInit, OnDestroy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Observable, BehaviorSubject, map, skip, first, defaultIfEmpty } from 'rxjs';\nimport { AbstractPopoverDirective } from '../popover/abstract.popover.directive';\nimport { DbxPopoverComponent } from '../popover/popover.component';\nimport { DbxPopoverConfigSizing, DbxPopoverService } from '../popover/popover.service';\nimport { FilterSource, FilterSourceConnector, PresetFilterSource, filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\nimport { Maybe } from '@dereekb/util';\n\nexport interface DbxFilterComponentParams<F extends object = object, P extends string = string> extends DbxPopoverConfigSizing {\n  /**\n   * Custom icon\n   *\n   * Defaults to \"filter_list\"\n   */\n  icon?: string;\n  /**\n   * Custom header text\n   *\n   * Defaults to \"Filter\"\n   */\n  header?: string;\n  /**\n   * Custom customize button text. If not defined, defaults to \"Customize\"\n   */\n  customizeButtonText?: string;\n  /**\n   * Custom close button text. If not defined, defaults to \"Close\"\n   */\n  closeButtonText?: string;\n  /**\n   * Whether or not to show the close button. Defaults to the value of !closeOnFilterChange\n   */\n  showCloseButton?: Maybe<boolean>;\n  /**\n   * Custom filter component to initialize.\n   */\n  customFilterComponentClass?: Type<FilterSource<F>>;\n  /**\n   * Preset filter component to initialize.\n   */\n  presetFilterComponentClass?: Type<PresetFilterSource<F, P>>;\n  /**\n   * The connector to use.\n   */\n  connector: FilterSourceConnector<F>;\n  /**\n   * (Optional) Inital filter to pass to the filter source.\n   */\n  initialFilterObs?: Observable<F>;\n  /**\n   * (Optional) Whether or not to close the component if the filter changes.\n   *\n   * True by default.\n   */\n  closeOnFilterChange?: boolean;\n}\n\nexport interface DbxFilterPopoverComponentParams<F extends object = object> extends DbxFilterComponentParams<F> {\n  /**\n   * Origin to add the popover to.\n   */\n  origin: ElementRef;\n}\n\nexport const DEFAULT_FILTER_POPOVER_KEY = 'filter';\n\n@Component({\n  templateUrl: './filter.popover.component.html'\n})\nexport class DbxFilterPopoverComponent<F extends object> extends AbstractPopoverDirective<unknown, DbxFilterComponentParams<F>> implements OnInit, OnDestroy {\n  private _closeOnChangeSub = new SubscriptionObject();\n\n  readonly showCloseButton = this.config.showCloseButton ?? !(this.config.closeOnFilterChange ?? true);\n  readonly closeButtonText = this.config.closeButtonText ?? 'Close';\n  readonly customizeButtonText = this.config.customizeButtonText ?? 'Customize';\n\n  /**\n   * Whether or not to display buttons to toggle between custom and preset filters.\n   */\n  readonly showSwitchButtons = Boolean(this.config.customFilterComponentClass && this.config.presetFilterComponentClass);\n\n  private _showPreset = new BehaviorSubject<boolean>(false);\n  readonly showPreset$ = this._showPreset.asObservable();\n\n  readonly config$: Observable<DbxInjectionComponentConfig<FilterSource<F>>> = this._showPreset.pipe(\n    map((showPreset) => {\n      const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass } = this.config;\n      let componentClass: Type<FilterSource<F>>;\n\n      if (showPreset) {\n        componentClass = presetFilterComponentClass as Type<FilterSource<F>>;\n      } else {\n        componentClass = customFilterComponentClass as Type<FilterSource<F>>;\n      }\n\n      const config: DbxInjectionComponentConfig<FilterSource<F>> = {\n        componentClass,\n        init: (filterSource) => {\n          connector.connectWithSource(filterSource);\n\n          if (initialFilterObs && filterSource.initWithFilter) {\n            filterSource.initWithFilter(initialFilterObs);\n          }\n\n          if (closeOnFilterChange !== false) {\n            this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {\n              this.close();\n            });\n          }\n        }\n      };\n\n      return config;\n    })\n  );\n\n  static openPopover<F extends object>(popupService: DbxPopoverService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, connector, initialFilterObs, closeOnFilterChange, customizeButtonText, showCloseButton, closeButtonText }: DbxFilterPopoverComponentParams<F>, popoverKey?: DbxPopoverKey): NgPopoverRef {\n    return popupService.open({\n      key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,\n      origin,\n      componentClass: DbxFilterPopoverComponent,\n      width,\n      height,\n      isResizable,\n      data: {\n        header,\n        icon,\n        customizeButtonText,\n        showCloseButton,\n        closeButtonText,\n        customFilterComponentClass,\n        presetFilterComponentClass,\n        connector,\n        initialFilterObs,\n        closeOnFilterChange\n      } as DbxFilterComponentParams<F>\n    });\n  }\n\n  constructor(popover: DbxPopoverComponent<unknown, DbxFilterComponentParams<F>>) {\n    super(popover);\n  }\n\n  get config(): DbxFilterComponentParams<F> {\n    return this.popover.data as DbxFilterComponentParams<F>;\n  }\n\n  get icon() {\n    return this.config.icon ?? 'filter_list';\n  }\n\n  get header() {\n    return this.config.header ?? 'Filter';\n  }\n\n  ngOnInit(): void {\n    let showPreset = false;\n    const { customFilterComponentClass, presetFilterComponentClass } = this.config;\n\n    if (customFilterComponentClass) {\n      showPreset = false;\n    }\n\n    if (presetFilterComponentClass) {\n      showPreset = true;\n    }\n\n    if (!customFilterComponentClass && !presetFilterComponentClass) {\n      throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');\n    }\n\n    this._showPreset.next(showPreset);\n  }\n\n  ngOnDestroy(): void {\n    this._closeOnChangeSub.destroy();\n    this._showPreset.complete();\n  }\n\n  showPresets() {\n    this._showPreset.next(true);\n  }\n\n  showCustom() {\n    this._showPreset.next(false);\n  }\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    <ng-container *ngIf=\"showSwitchButtons\" [ngSwitch]=\"showPreset$ | async\">\n      <button *ngSwitchCase=\"true\" mat-flat-button color=\"accent\" (click)=\"showCustom()\">{{ customizeButtonText }}</button>\n      <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n    </ng-container>\n    <ng-container *ngIf=\"showCloseButton\">\n      <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n      <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</button>\n    </ng-container>\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.popover.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.ts","../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.popover.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAuC,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAc,eAAe,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AACrF,OAAO,EAAE,wBAAwB,EAAE,MAAM,uCAAuC,CAAC;AACjF,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAEnE,OAAO,EAA2D,WAAW,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;AAoEzH,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAAC;AAKnD,MAAM,OAAO,yBAA4C,SAAQ,wBAA8D;IA+E7H,YAAY,OAAkE;QAC5E,KAAK,CAAC,OAAO,CAAC,CAAC;QA/ET,sBAAiB,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAE5C,oBAAe,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,mBAAmB,IAAI,IAAI,CAAC,CAAC;QAC5F,oBAAe,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,IAAI,OAAO,CAAC;QACzD,wBAAmB,GAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB,IAAI,WAAW,CAAC;QAE9E;;WAEG;QACM,sBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,0BAA0B,IAAI,IAAI,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAE/G,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACjD,gBAAW,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC;QAE9C,YAAO,GAA6D,IAAI,CAAC,WAAW,CAAC,IAAI,CAChG,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;YACjB,MAAM,EAAE,mBAAmB,GAAG,IAAI,EAAE,SAAS,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,2BAA2B,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;YAClM,IAAI,cAAqC,CAAC;YAC1C,IAAI,UAA+D,CAAC;YAEpE,IAAI,UAAU,EAAE;gBACd,cAAc,GAAG,CAAC,2BAA2B,EAAE,cAAc,IAAI,0BAA0B,CAA0B,CAAC;gBACtH,UAAU,GAAG,2BAA2B,CAAC;aAC1C;iBAAM;gBACL,cAAc,GAAG,CAAC,2BAA2B,EAAE,cAAc,IAAI,0BAA0B,CAA0B,CAAC;gBACtH,UAAU,GAAG,2BAA2B,CAAC;aAC1C;YAED,MAAM,MAAM,GAAiD;gBAC3D,GAAG,UAAU;gBACb,cAAc;gBACd,IAAI,EAAE,CAAC,YAAY,EAAE,EAAE;oBACrB,SAAS,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC;oBAE1C,IAAI,gBAAgB,IAAI,YAAY,CAAC,cAAc,EAAE;wBACnD,YAAY,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;qBAC/C;oBAED,IAAI,mBAAmB,KAAK,KAAK,EAAE;wBACjC,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,EAAE,KAAK,EAAE,EAAE,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;4BACzI,IAAI,CAAC,KAAK,EAAE,CAAC;wBACf,CAAC,CAAC,CAAC;qBACJ;oBAED,gCAAgC;oBAChC,UAAU,EAAE,IAAI,EAAE,CAAC,YAAY,CAAC,CAAC;gBACnC,CAAC;aACF,CAAC;YAEF,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IA6BF,CAAC;IA3BD,MAAM,CAAC,WAAW,CAAmB,YAA+B,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,2BAA2B,EAAE,SAAS,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,eAAe,EAAE,eAAe,EAAsC,EAAE,UAA0B;QACnZ,OAAO,YAAY,CAAC,IAAI,CAAC;YACvB,GAAG,EAAE,UAAU,IAAI,0BAA0B;YAC7C,MAAM;YACN,cAAc,EAAE,yBAAyB;YACzC,KAAK;YACL,MAAM;YACN,WAAW;YACX,IAAI,EAAE;gBACJ,MAAM;gBACN,IAAI;gBACJ,mBAAmB;gBACnB,eAAe;gBACf,eAAe;gBACf,0BAA0B;gBAC1B,0BAA0B;gBAC1B,2BAA2B;gBAC3B,2BAA2B;gBAC3B,SAAS;gBACT,gBAAgB;gBAChB,mBAAmB;aACW;SACjC,CAAC,CAAC;IACL,CAAC;IAMD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,IAAmC,CAAC;IAC1D,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,aAAa,CAAC;IAC3C,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;IACxC,CAAC;IAED,QAAQ;QACN,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,MAAM,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,2BAA2B,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAEzI,IAAI,0BAA0B,IAAI,2BAA2B,EAAE;YAC7D,UAAU,GAAG,KAAK,CAAC;SACpB;QAED,IAAI,0BAA0B,IAAI,2BAA2B,EAAE;YAC7D,UAAU,GAAG,IAAI,CAAC;SACnB;QAED,IAAI,CAAC,CAAC,0BAA0B,IAAI,2BAA2B,CAAC,IAAI,CAAC,CAAC,0BAA0B,IAAI,2BAA2B,CAAC,EAAE;YAChI,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;SACrF;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,CAAC;QACjC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;;uHA7HU,yBAAyB;2GAAzB,yBAAyB,2EChFtC,k4BAiBA;4FD+Da,yBAAyB;kBAHrC,SAAS","sourcesContent":["import { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { Component, ElementRef, Type, OnInit, OnDestroy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Observable, BehaviorSubject, map, skip, first, defaultIfEmpty } from 'rxjs';\nimport { AbstractPopoverDirective } from '../popover/abstract.popover.directive';\nimport { DbxPopoverComponent } from '../popover/popover.component';\nimport { DbxPopoverConfigSizing, DbxPopoverService } from '../popover/popover.service';\nimport { FilterSource, FilterSourceConnector, PresetFilterSource, filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { DbxPopoverKey } from '../popover/popover';\nimport { Maybe } from '@dereekb/util';\n\nexport interface DbxFilterComponentParams<F extends object = object, P extends string = string, CF extends FilterSource<F> = FilterSource<F>, PF extends PresetFilterSource<F, P> = PresetFilterSource<F, P>> extends DbxPopoverConfigSizing {\n  /**\n   * Custom icon\n   *\n   * Defaults to \"filter_list\"\n   */\n  icon?: string;\n  /**\n   * Custom header text\n   *\n   * Defaults to \"Filter\"\n   */\n  header?: string;\n  /**\n   * Custom customize button text. If not defined, defaults to \"Customize\"\n   */\n  customizeButtonText?: string;\n  /**\n   * Custom close button text. If not defined, defaults to \"Close\"\n   */\n  closeButtonText?: string;\n  /**\n   * Whether or not to show the close button. Defaults to the value of !closeOnFilterChange\n   */\n  showCloseButton?: Maybe<boolean>;\n  /**\n   * Custom filter component to initialize.\n   */\n  customFilterComponentClass?: Type<CF>;\n  /**\n   * Preset filter component to initialize.\n   */\n  presetFilterComponentClass?: Type<PF>;\n  /**\n   * DbxInjectionComponentConfig for the custom filter component to initialize.\n   */\n  customFilterComponentConfig?: DbxInjectionComponentConfig<CF>;\n  /**\n   * DbxInjectionComponentConfig for the preset filter component to initialize.\n   */\n  presetFilterComponentConfig?: DbxInjectionComponentConfig<PF>;\n  /**\n   * The connector to use.\n   */\n  connector: FilterSourceConnector<F>;\n  /**\n   * (Optional) Inital filter to pass to the filter source.\n   */\n  initialFilterObs?: Observable<F>;\n  /**\n   * (Optional) Whether or not to close the component if the filter changes.\n   *\n   * True by default.\n   */\n  closeOnFilterChange?: boolean;\n}\n\nexport interface DbxFilterPopoverComponentParams<F extends object = object> extends DbxFilterComponentParams<F> {\n  /**\n   * Origin to add the popover to.\n   */\n  origin: ElementRef;\n}\n\nexport const DEFAULT_FILTER_POPOVER_KEY = 'filter';\n\n@Component({\n  templateUrl: './filter.popover.component.html'\n})\nexport class DbxFilterPopoverComponent<F extends object> extends AbstractPopoverDirective<unknown, DbxFilterComponentParams<F>> implements OnInit, OnDestroy {\n  private _closeOnChangeSub = new SubscriptionObject();\n\n  readonly showCloseButton = this.config.showCloseButton ?? !(this.config.closeOnFilterChange ?? true);\n  readonly closeButtonText = this.config.closeButtonText ?? 'Close';\n  readonly customizeButtonText = this.config.customizeButtonText ?? 'Customize';\n\n  /**\n   * Whether or not to display buttons to toggle between custom and preset filters.\n   */\n  readonly showSwitchButtons = Boolean(this.config.customFilterComponentClass && this.config.presetFilterComponentClass);\n\n  private _showPreset = new BehaviorSubject<boolean>(false);\n  readonly showPreset$ = this._showPreset.asObservable();\n\n  readonly config$: Observable<DbxInjectionComponentConfig<FilterSource<F>>> = this._showPreset.pipe(\n    map((showPreset) => {\n      const { closeOnFilterChange = true, connector, initialFilterObs, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;\n      let componentClass: Type<FilterSource<F>>;\n      let baseConfig: Maybe<DbxInjectionComponentConfig<FilterSource<F>>>;\n\n      if (showPreset) {\n        componentClass = (presetFilterComponentConfig?.componentClass ?? presetFilterComponentClass) as Type<FilterSource<F>>;\n        baseConfig = presetFilterComponentConfig;\n      } else {\n        componentClass = (customFilterComponentConfig?.componentClass ?? customFilterComponentClass) as Type<FilterSource<F>>;\n        baseConfig = customFilterComponentConfig;\n      }\n\n      const config: DbxInjectionComponentConfig<FilterSource<F>> = {\n        ...baseConfig,\n        componentClass,\n        init: (filterSource) => {\n          connector.connectWithSource(filterSource);\n\n          if (initialFilterObs && filterSource.initWithFilter) {\n            filterSource.initWithFilter(initialFilterObs);\n          }\n\n          if (closeOnFilterChange !== false) {\n            this._closeOnChangeSub.subscription = filterSource.filter$.pipe(skip(1), filterMaybe(), first(), defaultIfEmpty(undefined)).subscribe(() => {\n              this.close();\n            });\n          }\n\n          // run the next init if provided\n          baseConfig?.init?.(filterSource);\n        }\n      };\n\n      return config;\n    })\n  );\n\n  static openPopover<F extends object>(popupService: DbxPopoverService, { width, height, isResizable, origin, header, icon, customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig, connector, initialFilterObs, closeOnFilterChange, customizeButtonText, showCloseButton, closeButtonText }: DbxFilterPopoverComponentParams<F>, popoverKey?: DbxPopoverKey): NgPopoverRef {\n    return popupService.open({\n      key: popoverKey ?? DEFAULT_FILTER_POPOVER_KEY,\n      origin,\n      componentClass: DbxFilterPopoverComponent,\n      width,\n      height,\n      isResizable,\n      data: {\n        header,\n        icon,\n        customizeButtonText,\n        showCloseButton,\n        closeButtonText,\n        customFilterComponentClass,\n        presetFilterComponentClass,\n        customFilterComponentConfig,\n        presetFilterComponentConfig,\n        connector,\n        initialFilterObs,\n        closeOnFilterChange\n      } as DbxFilterComponentParams<F>\n    });\n  }\n\n  constructor(popover: DbxPopoverComponent<unknown, DbxFilterComponentParams<F>>) {\n    super(popover);\n  }\n\n  get config(): DbxFilterComponentParams<F> {\n    return this.popover.data as DbxFilterComponentParams<F>;\n  }\n\n  get icon() {\n    return this.config.icon ?? 'filter_list';\n  }\n\n  get header() {\n    return this.config.header ?? 'Filter';\n  }\n\n  ngOnInit(): void {\n    let showPreset = false;\n    const { customFilterComponentClass, presetFilterComponentClass, customFilterComponentConfig, presetFilterComponentConfig } = this.config;\n\n    if (customFilterComponentClass || customFilterComponentConfig) {\n      showPreset = false;\n    }\n\n    if (presetFilterComponentClass || presetFilterComponentConfig) {\n      showPreset = true;\n    }\n\n    if (!(customFilterComponentClass || customFilterComponentConfig) && !(presetFilterComponentClass || presetFilterComponentConfig)) {\n      throw new Error('Requires a preset or custom class provided for DbxFilterPopover.');\n    }\n\n    this._showPreset.next(showPreset);\n  }\n\n  ngOnDestroy(): void {\n    this._closeOnChangeSub.destroy();\n    this._showPreset.complete();\n  }\n\n  showPresets() {\n    this._showPreset.next(true);\n  }\n\n  showCustom() {\n    this._showPreset.next(false);\n  }\n}\n","<dbx-popover-content>\n  <!-- Header -->\n  <dbx-popover-header [icon]=\"icon\" [header]=\"header\">\n    <ng-container *ngIf=\"showSwitchButtons\" [ngSwitch]=\"showPreset$ | async\">\n      <button *ngSwitchCase=\"true\" mat-flat-button color=\"accent\" (click)=\"showCustom()\">{{ customizeButtonText }}</button>\n      <button *ngSwitchCase=\"false\" mat-flat-button color=\"accent\" (click)=\"showPresets()\">Presets</button>\n    </ng-container>\n    <ng-container *ngIf=\"showCloseButton\">\n      <dbx-button-spacer *ngIf=\"showSwitchButtons\"></dbx-button-spacer>\n      <button mat-stroked-button color=\"accent\" (click)=\"close()\">{{ closeButtonText }}</button>\n    </ng-container>\n  </dbx-popover-header>\n  <!-- Content -->\n  <dbx-popover-scroll-content>\n    <dbx-injection [config]=\"config$ | async\"></dbx-injection>\n  </dbx-popover-scroll-content>\n</dbx-popover-content>\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { shareReplay, BehaviorSubject, map, combineLatest, distinctUntilChanged, startWith } from 'rxjs';
|
|
2
|
-
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { Directive, EventEmitter, Input, Output } from '@angular/core';
|
|
3
3
|
import { FilterSourceDirective, isClickableFilterPreset } from '@dereekb/dbx-core';
|
|
4
4
|
import { getValueFromGetter, objectHasNoKeys } from '@dereekb/util';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -11,6 +11,7 @@ export class AbstractDbxPresetFilterMenuComponent {
|
|
|
11
11
|
constructor(filterSourceDirective) {
|
|
12
12
|
this.filterSourceDirective = filterSourceDirective;
|
|
13
13
|
//TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes
|
|
14
|
+
this.presetSelected = new EventEmitter();
|
|
14
15
|
this._presets = new BehaviorSubject([]);
|
|
15
16
|
this.selected$ = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));
|
|
16
17
|
this.presetsWithPresetStringOnly$ = this._presets.pipe(map((x) => x.filter((y) => Boolean(y.preset))));
|
|
@@ -74,16 +75,20 @@ export class AbstractDbxPresetFilterMenuComponent {
|
|
|
74
75
|
}
|
|
75
76
|
this.filterSourceDirective.setFilter(filter);
|
|
76
77
|
}
|
|
78
|
+
this.presetSelected.next(preset);
|
|
77
79
|
}
|
|
78
80
|
ngOnDestroy() {
|
|
79
81
|
this._presets.complete();
|
|
82
|
+
this.presetSelected.complete();
|
|
80
83
|
}
|
|
81
84
|
}
|
|
82
85
|
AbstractDbxPresetFilterMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxPresetFilterMenuComponent, deps: [{ token: i1.FilterSourceDirective }], target: i0.ɵɵFactoryTarget.Directive });
|
|
83
|
-
AbstractDbxPresetFilterMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: AbstractDbxPresetFilterMenuComponent, inputs: { presets: "presets" }, ngImport: i0 });
|
|
86
|
+
AbstractDbxPresetFilterMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: AbstractDbxPresetFilterMenuComponent, inputs: { presets: "presets" }, outputs: { presetSelected: "presetSelected" }, ngImport: i0 });
|
|
84
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AbstractDbxPresetFilterMenuComponent, decorators: [{
|
|
85
88
|
type: Directive
|
|
86
|
-
}], ctorParameters: function () { return [{ type: i1.FilterSourceDirective }]; }, propDecorators: {
|
|
89
|
+
}], ctorParameters: function () { return [{ type: i1.FilterSourceDirective }]; }, propDecorators: { presetSelected: [{
|
|
90
|
+
type: Output
|
|
91
|
+
}], presets: [{
|
|
87
92
|
type: Input
|
|
88
93
|
}] } });
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.preset.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.preset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,EAAc,aAAa,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACrH,OAAO,EAAE,SAAS,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AAC5D,OAAO,EAA8C,qBAAqB,EAAsE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AACnM,OAAO,EAAE,kBAAkB,EAAS,eAAe,EAAE,MAAM,eAAe,CAAC;;;AAG3E;;GAEG;AAEH,MAAM,OAAgB,oCAAoC;IAyExD,YAAqB,qBAA+C;QAA/C,0BAAqB,GAArB,qBAAqB,CAA0B;QAxEpE,iFAAiF;QAEzE,aAAQ,GAAG,IAAI,eAAe,CAA4C,EAAE,CAAC,CAAC;QAE7E,cAAS,GAAyB,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACxI,iCAA4B,GAA2C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAE,CAA8B,CAAC,MAAM,CAAC,CAA+B,CAAC,CAAC,CAAC;QAEtM,0BAAqB,GAA8B,IAAI,CAAC,SAAS,CAAC,IAAI,CAC7E,GAAG,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAC7E,oBAAoB,EAAE,CACvB,CAAC;QAEO,wBAAmB,GAA6G,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CACtN,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,CAAC,EAAE,EAAE;YAC1D,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACvB,IAAI,QAAiB,CAAC;gBACtB,IAAI,IAAgC,CAAC;gBAErC,IAAI,uBAAuB,CAAC,CAAC,CAAC,EAAE;oBAC9B,QAAQ,GAAG,CAAC,CAAC,MAAM,KAAK,oBAAoB,CAAC;oBAC7C,IAAI,GAAG,QAAQ,CAAC;iBACjB;qBAAM;oBACL,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;oBAC1C,IAAI,GAAG,eAAe,CAAC;iBACxB;gBAED,OAAO;oBACL,IAAI;oBACJ,CAAC;oBACD;wBACE,GAAG,CAAC;wBACJ,QAAQ;wBACR,OAAO,EAAE,GAAG,EAAE;4BACZ,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;wBACvB,CAAC;qBACF;iBAC6E,CAAC;YACnF,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,mBAAc,GAAsC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACxF,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAC9B,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,6BAAwB,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC/D,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,MAAM,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YACzD,OAAO,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;QACnD,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,oBAAe,GAAgD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACnG,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,MAAM,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YAC1F,OAAO,aAAa,CAAC,CAAC,CAAE,aAAa,CAAC,CAAC,CAA8B,CAAC,CAAC,CAAC,SAAS,CAAC;QACpF,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAWqE,CAAC;IATxE,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;IAC7B,CAAC;IAED,IAAI,OAAO,CAAC,OAAkD;QAC5D,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAID,YAAY,CAAC,MAA+C;QAC1D,MAAM,YAAY,GAAI,MAAmC,CAAC,MAAM,CAAC;QACjE,MAAM,WAAW,GAAI,MAAmC,CAAC,WAAW,IAAK,MAA0C,CAAC,kBAAkB,CAAC;QAEvI,IAAI,WAAW,IAAI,IAAI,IAAI,CAAC,OAAO,WAAW,KAAK,UAAU,IAAI,eAAe,CAAC,WAAW,CAAC,CAAC,EAAE;YAC9F,mDAAmD;YACnD,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC,WAAW,IAAI,EAAE,CAAM,CAAC,CAAC;YAC/D,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;SAC1C;aAAM;YACL,IAAI,MAAM,GAAG,kBAAkB,CAAC,WAAW,CAAM,CAAC;YAElD,IAAI,MAAM,CAAC,MAAM,KAAK,YAAY,EAAE;gBAClC,MAAM,GAAG;oBACP,GAAG,MAAM;oBACT,MAAM,EAAE,YAAY;iBACrB,CAAC;aACH;YAED,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;SAC9C;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;kIAnGmB,oCAAoC;sHAApC,oCAAoC;4FAApC,oCAAoC;kBADzD,SAAS;4GAkEJ,OAAO;sBADV,KAAK","sourcesContent":["import { shareReplay, BehaviorSubject, map, Observable, combineLatest, distinctUntilChanged, startWith } from 'rxjs';\nimport { Directive, Input, OnDestroy } from '@angular/core';\nimport { ClickableFilterPreset, ClickableAnchorLink, FilterSourceDirective, ClickablePartialFilterPreset, ClickableFilterPresetOrPartialPreset, isClickableFilterPreset } from '@dereekb/dbx-core';\nimport { getValueFromGetter, Maybe, objectHasNoKeys } from '@dereekb/util';\nimport { FilterWithPreset } from '@dereekb/rxjs';\n\n/**\n * Displays a button and menu for filtering presets.\n */\n@Directive()\nexport abstract class AbstractDbxPresetFilterMenuComponent<F extends FilterWithPreset> implements OnDestroy {\n  //TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes\n\n  private _presets = new BehaviorSubject<ClickableFilterPresetOrPartialPreset<F>[]>([]);\n\n  readonly selected$: Observable<Maybe<F>> = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));\n  readonly presetsWithPresetStringOnly$: Observable<ClickableFilterPreset<F>[]> = this._presets.pipe(map((x) => x.filter((y) => Boolean((y as ClickableFilterPreset<F>).preset)) as ClickableFilterPreset<F>[]));\n\n  readonly selectedPresetString$: Observable<Maybe<string>> = this.selected$.pipe(\n    map((selectedFilter) => (selectedFilter ? selectedFilter.preset : undefined)),\n    distinctUntilChanged()\n  );\n\n  readonly presetAnchorsPairs$: Observable<['preset' | 'partialPreset', ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink][]> = combineLatest([this._presets, this.selected$, this.selectedPresetString$]).pipe(\n    map(([presets, currentFilterValue, selectedPresetString]) => {\n      return presets.map((x) => {\n        let selected: boolean;\n        let type: 'preset' | 'partialPreset';\n\n        if (isClickableFilterPreset(x)) {\n          selected = x.preset === selectedPresetString;\n          type = 'preset';\n        } else {\n          selected = x.isActive(currentFilterValue);\n          type = 'partialPreset';\n        }\n\n        return [\n          type,\n          x,\n          {\n            ...x,\n            selected,\n            onClick: () => {\n              this.selectPreset(x);\n            }\n          }\n        ] as [typeof type, ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink];\n      });\n    }),\n    shareReplay(1)\n  );\n\n  readonly presetAnchors$: Observable<ClickableAnchorLink[]> = this.presetAnchorsPairs$.pipe(\n    map((x) => x.map((x) => x[2])),\n    shareReplay(1)\n  );\n\n  readonly firstSelectedAnchorPair$ = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.find((x) => x[2].selected);\n      return firstSelected ? firstSelected : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  readonly selectedPreset$: Observable<Maybe<ClickableFilterPreset<F>>> = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.filter((x) => x[0] === 'preset').find((x) => x[2].selected);\n      return firstSelected ? (firstSelected[1] as ClickableFilterPreset<F>) : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  @Input()\n  get presets(): ClickableFilterPresetOrPartialPreset<F>[] {\n    return this._presets.value;\n  }\n\n  set presets(presets: ClickableFilterPresetOrPartialPreset<F>[]) {\n    this._presets.next(presets);\n  }\n\n  constructor(readonly filterSourceDirective: FilterSourceDirective<F>) {}\n\n  selectPreset(preset: ClickableFilterPresetOrPartialPreset<F>) {\n    const presetString = (preset as ClickableFilterPreset<F>).preset;\n    const presetValue = (preset as ClickableFilterPreset<F>).presetValue || (preset as ClickablePartialFilterPreset<F>).partialPresetValue;\n\n    if (presetValue == null || (typeof presetValue !== 'function' && objectHasNoKeys(presetValue))) {\n      // set and then reset if the value is null or empty\n      this.filterSourceDirective.setFilter((presetValue ?? {}) as F);\n      this.filterSourceDirective.resetFilter();\n    } else {\n      let filter = getValueFromGetter(presetValue) as F;\n\n      if (filter.preset !== presetString) {\n        filter = {\n          ...filter,\n          preset: presetString\n        };\n      }\n\n      this.filterSourceDirective.setFilter(filter);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._presets.complete();\n  }\n}\n"]}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.preset.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/filter/filter.preset.ts"],"names":[],"mappings":"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","sourcesContent":["import { shareReplay, BehaviorSubject, map, Observable, combineLatest, distinctUntilChanged, startWith } from 'rxjs';\nimport { Directive, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { ClickableFilterPreset, ClickableAnchorLink, FilterSourceDirective, ClickablePartialFilterPreset, ClickableFilterPresetOrPartialPreset, isClickableFilterPreset } from '@dereekb/dbx-core';\nimport { getValueFromGetter, Maybe, objectHasNoKeys } from '@dereekb/util';\nimport { FilterWithPreset } from '@dereekb/rxjs';\n\n/**\n * Displays a button and menu for filtering presets.\n */\n@Directive()\nexport abstract class AbstractDbxPresetFilterMenuComponent<F extends FilterWithPreset> implements OnDestroy {\n  //TODO: Rename to AbstractDbxPresetFilterMenuDirective with next breaking changes\n\n  @Output()\n  presetSelected = new EventEmitter<ClickableFilterPresetOrPartialPreset<F>>();\n\n  private _presets = new BehaviorSubject<ClickableFilterPresetOrPartialPreset<F>[]>([]);\n\n  readonly selected$: Observable<Maybe<F>> = this.filterSourceDirective.filter$.pipe(startWith(undefined), distinctUntilChanged(), shareReplay(1));\n  readonly presetsWithPresetStringOnly$: Observable<ClickableFilterPreset<F>[]> = this._presets.pipe(map((x) => x.filter((y) => Boolean((y as ClickableFilterPreset<F>).preset)) as ClickableFilterPreset<F>[]));\n\n  readonly selectedPresetString$: Observable<Maybe<string>> = this.selected$.pipe(\n    map((selectedFilter) => (selectedFilter ? selectedFilter.preset : undefined)),\n    distinctUntilChanged()\n  );\n\n  readonly presetAnchorsPairs$: Observable<['preset' | 'partialPreset', ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink][]> = combineLatest([this._presets, this.selected$, this.selectedPresetString$]).pipe(\n    map(([presets, currentFilterValue, selectedPresetString]) => {\n      return presets.map((x) => {\n        let selected: boolean;\n        let type: 'preset' | 'partialPreset';\n\n        if (isClickableFilterPreset(x)) {\n          selected = x.preset === selectedPresetString;\n          type = 'preset';\n        } else {\n          selected = x.isActive(currentFilterValue);\n          type = 'partialPreset';\n        }\n\n        return [\n          type,\n          x,\n          {\n            ...x,\n            selected,\n            onClick: () => {\n              this.selectPreset(x);\n            }\n          }\n        ] as [typeof type, ClickableFilterPresetOrPartialPreset<F>, ClickableAnchorLink];\n      });\n    }),\n    shareReplay(1)\n  );\n\n  readonly presetAnchors$: Observable<ClickableAnchorLink[]> = this.presetAnchorsPairs$.pipe(\n    map((x) => x.map((x) => x[2])),\n    shareReplay(1)\n  );\n\n  readonly firstSelectedAnchorPair$ = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.find((x) => x[2].selected);\n      return firstSelected ? firstSelected : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  readonly selectedPreset$: Observable<Maybe<ClickableFilterPreset<F>>> = this.presetAnchorsPairs$.pipe(\n    map((presets) => {\n      const firstSelected = presets.filter((x) => x[0] === 'preset').find((x) => x[2].selected);\n      return firstSelected ? (firstSelected[1] as ClickableFilterPreset<F>) : undefined;\n    }),\n    shareReplay(1)\n  );\n\n  @Input()\n  get presets(): ClickableFilterPresetOrPartialPreset<F>[] {\n    return this._presets.value;\n  }\n\n  set presets(presets: ClickableFilterPresetOrPartialPreset<F>[]) {\n    this._presets.next(presets);\n  }\n\n  constructor(readonly filterSourceDirective: FilterSourceDirective<F>) {}\n\n  selectPreset(preset: ClickableFilterPresetOrPartialPreset<F>) {\n    const presetString = (preset as ClickableFilterPreset<F>).preset;\n    const presetValue = (preset as ClickableFilterPreset<F>).presetValue || (preset as ClickablePartialFilterPreset<F>).partialPresetValue;\n\n    if (presetValue == null || (typeof presetValue !== 'function' && objectHasNoKeys(presetValue))) {\n      // set and then reset if the value is null or empty\n      this.filterSourceDirective.setFilter((presetValue ?? {}) as F);\n      this.filterSourceDirective.resetFilter();\n    } else {\n      let filter = getValueFromGetter(presetValue) as F;\n\n      if (filter.preset !== presetString) {\n        filter = {\n          ...filter,\n          preset: presetString\n        };\n      }\n\n      this.filterSourceDirective.setFilter(filter);\n    }\n\n    this.presetSelected.next(preset);\n  }\n\n  ngOnDestroy(): void {\n    this._presets.complete();\n    this.presetSelected.complete();\n  }\n}\n"]}
|