mapa-library-ui 0.0.16 → 0.0.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/src/lib/components/capability/lib/components/capability/capability-classification.const.mjs +57 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/capability-interval.const.mjs +63 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/capability.interfaces.mjs +1 -1
- package/esm2020/src/lib/components/capability/lib/components/capability/public-api.mjs +5 -3
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-detail/capability-detail.component.mjs +6 -6
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-detail/capability-detail.module.mjs +12 -12
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-dot/capability-dot.component.mjs +8 -8
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-expand/capability-expand.component.mjs +7 -9
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-indicator/capability-indicator.component.mjs +4 -3
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-indicator-list/capability-indicator-list.component.mjs +27 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-indicator-list/capability-indicator-list.module.mjs +19 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-interval/capability-interval.component.mjs +24 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-interval/capability-interval.module.mjs +18 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-interval-bar/capability-interval-bar.component.mjs +31 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-interval-bar/capability-interval-bar.module.mjs +20 -0
- package/esm2020/src/lib/components/capability/lib/components/capability/src/services/reusable-interval-bar.service.mjs +32 -0
- package/esm2020/src/lib/components/table/src/table.component.mjs +9 -6
- package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs +200 -107
- package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
- package/fesm2015/mapa-library-ui-src-lib-components-table.mjs +8 -5
- package/fesm2015/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs +199 -107
- package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-table.mjs +8 -5
- package/fesm2020/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
- package/mapa-library-ui-0.0.18.tgz +0 -0
- package/package.json +1 -1
- package/src/lib/components/capability/lib/components/capability/capability-classification.const.d.ts +6 -0
- package/src/lib/components/capability/lib/components/capability/capability-interval.const.d.ts +6 -0
- package/src/lib/components/capability/lib/components/capability/capability.interfaces.d.ts +8 -2
- package/src/lib/components/capability/lib/components/capability/public-api.d.ts +4 -2
- package/src/lib/components/capability/lib/components/capability/src/capability-detail/capability-detail.component.d.ts +1 -1
- package/src/lib/components/capability/lib/components/capability/src/capability-detail/capability-detail.module.d.ts +3 -3
- package/src/lib/components/capability/lib/components/capability/src/capability-dot/capability-dot.component.d.ts +1 -1
- package/src/lib/components/capability/lib/components/capability/src/capability-expand/capability-expand.component.d.ts +2 -2
- package/src/lib/components/capability/lib/components/capability/src/capability-indicator-list/capability-indicator-list.component.d.ts +14 -0
- package/src/lib/components/capability/lib/components/capability/src/capability-indicator-list/capability-indicator-list.module.d.ts +9 -0
- package/src/lib/components/capability/lib/components/capability/src/capability-interval/capability-interval.component.d.ts +8 -0
- package/src/lib/components/capability/lib/components/capability/src/capability-interval/capability-interval.module.d.ts +8 -0
- package/src/lib/components/capability/lib/components/capability/src/capability-interval-bar/capability-interval-bar.component.d.ts +13 -0
- package/src/lib/components/capability/lib/components/capability/src/capability-interval-bar/capability-interval-bar.module.d.ts +10 -0
- package/src/lib/components/capability/lib/components/capability/src/services/{reusable-grade-bar.service.d.ts → reusable-interval-bar.service.d.ts} +3 -3
- package/src/lib/components/table/src/table.component.d.ts +3 -2
- package/esm2020/src/lib/components/capability/lib/components/capability/capability-grade.const.mjs +0 -63
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-grade/capability-grade.component.mjs +0 -24
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-grade/capability-grade.module.mjs +0 -18
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-grade-bar/capability-grade-bar.component.mjs +0 -31
- package/esm2020/src/lib/components/capability/lib/components/capability/src/capability-grade-bar/capability-grade-bar.module.mjs +0 -20
- package/esm2020/src/lib/components/capability/lib/components/capability/src/services/reusable-grade-bar.service.mjs +0 -32
- package/mapa-library-ui-0.0.16.tgz +0 -0
- package/src/lib/components/capability/lib/components/capability/capability-grade.const.d.ts +0 -6
- package/src/lib/components/capability/lib/components/capability/src/capability-grade/capability-grade.component.d.ts +0 -8
- package/src/lib/components/capability/lib/components/capability/src/capability-grade/capability-grade.module.d.ts +0 -8
- package/src/lib/components/capability/lib/components/capability/src/capability-grade-bar/capability-grade-bar.component.d.ts +0 -13
- package/src/lib/components/capability/lib/components/capability/src/capability-grade-bar/capability-grade-bar.module.d.ts +0 -10
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Component, Input } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class MapaCapabilityIntervalComponent {
|
|
5
|
+
getintervalWidth(index) {
|
|
6
|
+
if (!this.data)
|
|
7
|
+
return 0;
|
|
8
|
+
const intervalMod10 = Math.floor(this.data.interval / 10) % 10;
|
|
9
|
+
return index < intervalMod10
|
|
10
|
+
? 100
|
|
11
|
+
: index === intervalMod10
|
|
12
|
+
? (this.data.interval % 10) * 10
|
|
13
|
+
: 0;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
MapaCapabilityIntervalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
17
|
+
MapaCapabilityIntervalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MapaCapabilityIntervalComponent, selector: "mapa-capability-interval", inputs: { data: "data" }, ngImport: i0, template: "<ul class=\"capability__interval\">\n <li class=\"capability__interval--item\" *ngFor=\"let item of [].constructor(9); let i = index\">\n <div\n class=\"capability__interval--percentage\"\n [style.width.%]=\"getintervalWidth(i)\"\n ></div>\n </li>\n <li>\n <h1>{{ data.interval }}</h1>\n </li>\n</ul>\n", styles: [".capability__interval{display:flex;list-style-type:none;margin-block-start:0px;margin-block-end:0px;padding-inline-start:0px}.capability__interval h1{margin-bottom:0;margin-left:16px}.capability__interval--item{height:35px;width:20px;background-color:#d9d9d9;border-radius:6px;margin-right:6px}.capability__interval--item:last-of-type{margin-right:0}.capability__interval--percentage{height:35px;width:20px;background-color:#8c8f94;border-radius:6px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalComponent, decorators: [{
|
|
19
|
+
type: Component,
|
|
20
|
+
args: [{ selector: "mapa-capability-interval", template: "<ul class=\"capability__interval\">\n <li class=\"capability__interval--item\" *ngFor=\"let item of [].constructor(9); let i = index\">\n <div\n class=\"capability__interval--percentage\"\n [style.width.%]=\"getintervalWidth(i)\"\n ></div>\n </li>\n <li>\n <h1>{{ data.interval }}</h1>\n </li>\n</ul>\n", styles: [".capability__interval{display:flex;list-style-type:none;margin-block-start:0px;margin-block-end:0px;padding-inline-start:0px}.capability__interval h1{margin-bottom:0;margin-left:16px}.capability__interval--item{height:35px;width:20px;background-color:#d9d9d9;border-radius:6px;margin-right:6px}.capability__interval--item:last-of-type{margin-right:0}.capability__interval--percentage{height:35px;width:20px;background-color:#8c8f94;border-radius:6px}\n"] }]
|
|
21
|
+
}], propDecorators: { data: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwYWJpbGl0eS1pbnRlcnZhbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb21wb25lbnRzL2NhcGFiaWxpdHkvc3JjL2NhcGFiaWxpdHktaW50ZXJ2YWwvY2FwYWJpbGl0eS1pbnRlcnZhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb21wb25lbnRzL2NhcGFiaWxpdHkvc3JjL2NhcGFiaWxpdHktaW50ZXJ2YWwvY2FwYWJpbGl0eS1pbnRlcnZhbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUWpELE1BQU0sT0FBTywrQkFBK0I7SUFHbkMsZ0JBQWdCLENBQUMsS0FBYTtRQUNuQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUk7WUFBRSxPQUFPLENBQUMsQ0FBQztRQUN6QixNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUMvRCxPQUFPLEtBQUssR0FBRyxhQUFhO1lBQzFCLENBQUMsQ0FBQyxHQUFHO1lBQ0wsQ0FBQyxDQUFDLEtBQUssS0FBSyxhQUFhO2dCQUN6QixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUMsR0FBRyxFQUFFO2dCQUNoQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQzs7NkhBWFUsK0JBQStCO2lIQUEvQiwrQkFBK0IsMEZDUjVDLHVVQVdBOzRGREhhLCtCQUErQjtrQkFMM0MsU0FBUzsrQkFDRSwwQkFBMEI7OEJBSzNCLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQ2FwYWJpbGl0eSB9IGZyb20gXCIuLi8uLi9jYXBhYmlsaXR5LmludGVyZmFjZXNcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiBcIm1hcGEtY2FwYWJpbGl0eS1pbnRlcnZhbFwiLFxuICB0ZW1wbGF0ZVVybDogXCIuL2NhcGFiaWxpdHktaW50ZXJ2YWwuY29tcG9uZW50Lmh0bWxcIixcbiAgc3R5bGVVcmxzOiBbXCIuL2NhcGFiaWxpdHktaW50ZXJ2YWwuY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIE1hcGFDYXBhYmlsaXR5SW50ZXJ2YWxDb21wb25lbnQge1xuICBASW5wdXQoKSBkYXRhITogQ2FwYWJpbGl0eTtcblxuICBwdWJsaWMgZ2V0aW50ZXJ2YWxXaWR0aChpbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICBpZiAoIXRoaXMuZGF0YSkgcmV0dXJuIDA7XG4gICAgY29uc3QgaW50ZXJ2YWxNb2QxMCA9IE1hdGguZmxvb3IodGhpcy5kYXRhLmludGVydmFsIC8gMTApICUgMTA7XG4gICAgcmV0dXJuIGluZGV4IDwgaW50ZXJ2YWxNb2QxMFxuICAgICAgPyAxMDBcbiAgICAgIDogaW5kZXggPT09IGludGVydmFsTW9kMTBcbiAgICAgID8gKHRoaXMuZGF0YS5pbnRlcnZhbCAlIDEwKSAqIDEwXG4gICAgICA6IDA7XG4gIH1cbn1cbiIsIjx1bCBjbGFzcz1cImNhcGFiaWxpdHlfX2ludGVydmFsXCI+XG4gIDxsaSBjbGFzcz1cImNhcGFiaWxpdHlfX2ludGVydmFsLS1pdGVtXCIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgW10uY29uc3RydWN0b3IoOSk7IGxldCBpID0gaW5kZXhcIj5cbiAgICA8ZGl2XG4gICAgICBjbGFzcz1cImNhcGFiaWxpdHlfX2ludGVydmFsLS1wZXJjZW50YWdlXCJcbiAgICAgIFtzdHlsZS53aWR0aC4lXT1cImdldGludGVydmFsV2lkdGgoaSlcIlxuICAgID48L2Rpdj5cbiAgPC9saT5cbiAgPGxpPlxuICAgIDxoMT57eyBkYXRhLmludGVydmFsIH19PC9oMT5cbiAgPC9saT5cbjwvdWw+XG4iXX0=
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { MapaCapabilityIntervalComponent } from "./capability-interval.component";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class MapaCapabilityIntervalModule {
|
|
6
|
+
}
|
|
7
|
+
MapaCapabilityIntervalModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
MapaCapabilityIntervalModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalModule, declarations: [MapaCapabilityIntervalComponent], imports: [CommonModule], exports: [MapaCapabilityIntervalComponent] });
|
|
9
|
+
MapaCapabilityIntervalModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalModule, imports: [CommonModule] });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
declarations: [MapaCapabilityIntervalComponent],
|
|
14
|
+
exports: [MapaCapabilityIntervalComponent],
|
|
15
|
+
imports: [CommonModule],
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwYWJpbGl0eS1pbnRlcnZhbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb21wb25lbnRzL2NhcGFiaWxpdHkvc3JjL2NhcGFiaWxpdHktaW50ZXJ2YWwvY2FwYWJpbGl0eS1pbnRlcnZhbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLCtCQUErQixFQUFFLE1BQU0saUNBQWlDLENBQUM7O0FBT2xGLE1BQU0sT0FBTyw0QkFBNEI7OzBIQUE1Qiw0QkFBNEI7MkhBQTVCLDRCQUE0QixpQkFKeEIsK0JBQStCLGFBRXBDLFlBQVksYUFEWiwrQkFBK0I7MkhBRzlCLDRCQUE0QixZQUY3QixZQUFZOzRGQUVYLDRCQUE0QjtrQkFMeEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQywrQkFBK0IsQ0FBQztvQkFDL0MsT0FBTyxFQUFFLENBQUMsK0JBQStCLENBQUM7b0JBQzFDLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztpQkFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBNYXBhQ2FwYWJpbGl0eUludGVydmFsQ29tcG9uZW50IH0gZnJvbSBcIi4vY2FwYWJpbGl0eS1pbnRlcnZhbC5jb21wb25lbnRcIjtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbTWFwYUNhcGFiaWxpdHlJbnRlcnZhbENvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtNYXBhQ2FwYWJpbGl0eUludGVydmFsQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG59KVxuZXhwb3J0IGNsYXNzIE1hcGFDYXBhYmlsaXR5SW50ZXJ2YWxNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../../../button/src/button.component";
|
|
5
|
+
import * as i3 from "../capability-interval/capability-interval.component";
|
|
6
|
+
export class MapaCapabilityIntervalBarComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.clicked = new EventEmitter();
|
|
9
|
+
this.isHovering = false;
|
|
10
|
+
}
|
|
11
|
+
onHover() {
|
|
12
|
+
this.isHovering = true;
|
|
13
|
+
}
|
|
14
|
+
onMouseOut() {
|
|
15
|
+
this.isHovering = false;
|
|
16
|
+
}
|
|
17
|
+
showMore() {
|
|
18
|
+
this.clicked.emit();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
MapaCapabilityIntervalBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
MapaCapabilityIntervalBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MapaCapabilityIntervalBarComponent, selector: "mapa-capability-interval-bar", inputs: { data: "data" }, outputs: { clicked: "clicked" }, ngImport: i0, template: "<div\n class=\"capability-interval\"\n (mouseover)=\"onHover()\"\n (mouseout)=\"onMouseOut()\"\n reusable-outlet\n>\n <mapa-capability-interval\n [ngClass]=\"{'capability-interval--hide': isHovering}\"\n [data]=\"data\"\n ></mapa-capability-interval>\n <span\n class=\"capability-interval--hide\"\n [ngClass]=\"{'capability-interval--show': isHovering}\"\n >\n <mapa-button color=\"basic\" (click)=\"showMore()\">Veja mais</mapa-button>\n </span>\n</div>\n", styles: [".capability-interval{border:1px solid #8c8f94;border-radius:16px;display:flex;align-items:center;justify-content:flex-end;padding:16px;height:35px;width:290px}.capability-interval--hide{display:none}.capability-interval--show{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.ButtonComponent, selector: "mapa-button", inputs: ["color", "disabled"], outputs: ["clicked"] }, { kind: "component", type: i3.MapaCapabilityIntervalComponent, selector: "mapa-capability-interval", inputs: ["data"] }] });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalBarComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: "mapa-capability-interval-bar", template: "<div\n class=\"capability-interval\"\n (mouseover)=\"onHover()\"\n (mouseout)=\"onMouseOut()\"\n reusable-outlet\n>\n <mapa-capability-interval\n [ngClass]=\"{'capability-interval--hide': isHovering}\"\n [data]=\"data\"\n ></mapa-capability-interval>\n <span\n class=\"capability-interval--hide\"\n [ngClass]=\"{'capability-interval--show': isHovering}\"\n >\n <mapa-button color=\"basic\" (click)=\"showMore()\">Veja mais</mapa-button>\n </span>\n</div>\n", styles: [".capability-interval{border:1px solid #8c8f94;border-radius:16px;display:flex;align-items:center;justify-content:flex-end;padding:16px;height:35px;width:290px}.capability-interval--hide{display:none}.capability-interval--show{display:block}\n"] }]
|
|
26
|
+
}], propDecorators: { data: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], clicked: [{
|
|
29
|
+
type: Output
|
|
30
|
+
}] } });
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwYWJpbGl0eS1pbnRlcnZhbC1iYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9jYXBhYmlsaXR5L3NyYy9jYXBhYmlsaXR5LWludGVydmFsLWJhci9jYXBhYmlsaXR5LWludGVydmFsLWJhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb21wb25lbnRzL2NhcGFiaWxpdHkvc3JjL2NhcGFiaWxpdHktaW50ZXJ2YWwtYmFyL2NhcGFiaWxpdHktaW50ZXJ2YWwtYmFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBUXZFLE1BQU0sT0FBTyxrQ0FBa0M7SUFML0M7UUFPWSxZQUFPLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFFMUQsZUFBVSxHQUFHLEtBQUssQ0FBQztLQWEzQjtJQVhDLE9BQU87UUFDTCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztJQUN6QixDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN0QixDQUFDOztnSUFoQlUsa0NBQWtDO29IQUFsQyxrQ0FBa0MsK0hDUi9DLGtlQWlCQTs0RkRUYSxrQ0FBa0M7a0JBTDlDLFNBQVM7K0JBQ0UsOEJBQThCOzhCQUsvQixJQUFJO3NCQUFaLEtBQUs7Z0JBQ0ksT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IENhcGFiaWxpdHkgfSBmcm9tIFwiLi4vLi4vY2FwYWJpbGl0eS5pbnRlcmZhY2VzXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJtYXBhLWNhcGFiaWxpdHktaW50ZXJ2YWwtYmFyXCIsXG4gIHRlbXBsYXRlVXJsOiBcIi4vY2FwYWJpbGl0eS1pbnRlcnZhbC1iYXIuY29tcG9uZW50Lmh0bWxcIixcbiAgc3R5bGVVcmxzOiBbXCIuL2NhcGFiaWxpdHktaW50ZXJ2YWwtYmFyLmNvbXBvbmVudC5zY3NzXCJdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXBhQ2FwYWJpbGl0eUludGVydmFsQmFyQ29tcG9uZW50IHtcbiAgQElucHV0KCkgZGF0YSE6IENhcGFiaWxpdHk7XG4gIEBPdXRwdXQoKSBjbGlja2VkOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gIFxuICBwdWJsaWMgaXNIb3ZlcmluZyA9IGZhbHNlO1xuXG4gIG9uSG92ZXIoKTogdm9pZCB7XG4gICAgdGhpcy5pc0hvdmVyaW5nID0gdHJ1ZTtcbiAgfVxuXG4gIG9uTW91c2VPdXQoKTogdm9pZCB7XG4gICAgdGhpcy5pc0hvdmVyaW5nID0gZmFsc2U7XG4gIH1cblxuICBzaG93TW9yZSgpOiB2b2lkIHtcbiAgICB0aGlzLmNsaWNrZWQuZW1pdCgpO1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiY2FwYWJpbGl0eS1pbnRlcnZhbFwiXG4gIChtb3VzZW92ZXIpPVwib25Ib3ZlcigpXCJcbiAgKG1vdXNlb3V0KT1cIm9uTW91c2VPdXQoKVwiXG4gIHJldXNhYmxlLW91dGxldFxuPlxuICA8bWFwYS1jYXBhYmlsaXR5LWludGVydmFsXG4gICAgW25nQ2xhc3NdPVwieydjYXBhYmlsaXR5LWludGVydmFsLS1oaWRlJzogaXNIb3ZlcmluZ31cIlxuICAgIFtkYXRhXT1cImRhdGFcIlxuICA+PC9tYXBhLWNhcGFiaWxpdHktaW50ZXJ2YWw+XG4gIDxzcGFuXG4gICAgY2xhc3M9XCJjYXBhYmlsaXR5LWludGVydmFsLS1oaWRlXCJcbiAgICBbbmdDbGFzc109XCJ7J2NhcGFiaWxpdHktaW50ZXJ2YWwtLXNob3cnOiBpc0hvdmVyaW5nfVwiXG4gID5cbiAgICA8bWFwYS1idXR0b24gY29sb3I9XCJiYXNpY1wiIChjbGljayk9XCJzaG93TW9yZSgpXCI+VmVqYSBtYWlzPC9tYXBhLWJ1dHRvbj5cbiAgPC9zcGFuPlxuPC9kaXY+XG4iXX0=
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { MapaCapabilityIntervalBarComponent } from "./capability-interval-bar.component";
|
|
4
|
+
import { MapaButtonModule } from "../../../../../filters";
|
|
5
|
+
import { MapaCapabilityIntervalModule } from "../capability-interval/capability-interval.module";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class MapaCapabilityIntervalBarModule {
|
|
8
|
+
}
|
|
9
|
+
MapaCapabilityIntervalBarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalBarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
MapaCapabilityIntervalBarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalBarModule, declarations: [MapaCapabilityIntervalBarComponent], imports: [CommonModule, MapaButtonModule, MapaCapabilityIntervalModule], exports: [MapaCapabilityIntervalBarComponent] });
|
|
11
|
+
MapaCapabilityIntervalBarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalBarModule, imports: [CommonModule, MapaButtonModule, MapaCapabilityIntervalModule] });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaCapabilityIntervalBarModule, decorators: [{
|
|
13
|
+
type: NgModule,
|
|
14
|
+
args: [{
|
|
15
|
+
declarations: [MapaCapabilityIntervalBarComponent],
|
|
16
|
+
exports: [MapaCapabilityIntervalBarComponent],
|
|
17
|
+
imports: [CommonModule, MapaButtonModule, MapaCapabilityIntervalModule],
|
|
18
|
+
}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwYWJpbGl0eS1pbnRlcnZhbC1iYXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9jYXBhYmlsaXR5L3NyYy9jYXBhYmlsaXR5LWludGVydmFsLWJhci9jYXBhYmlsaXR5LWludGVydmFsLWJhci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtDQUFrQyxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDekYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbURBQW1ELENBQUM7O0FBT2pHLE1BQU0sT0FBTywrQkFBK0I7OzZIQUEvQiwrQkFBK0I7OEhBQS9CLCtCQUErQixpQkFKM0Isa0NBQWtDLGFBRXZDLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSw0QkFBNEIsYUFENUQsa0NBQWtDOzhIQUdqQywrQkFBK0IsWUFGaEMsWUFBWSxFQUFFLGdCQUFnQixFQUFFLDRCQUE0Qjs0RkFFM0QsK0JBQStCO2tCQUwzQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGtDQUFrQyxDQUFDO29CQUNsRCxPQUFPLEVBQUUsQ0FBQyxrQ0FBa0MsQ0FBQztvQkFDN0MsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGdCQUFnQixFQUFFLDRCQUE0QixDQUFDO2lCQUN4RSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE1hcGFDYXBhYmlsaXR5SW50ZXJ2YWxCYXJDb21wb25lbnQgfSBmcm9tIFwiLi9jYXBhYmlsaXR5LWludGVydmFsLWJhci5jb21wb25lbnRcIjtcbmltcG9ydCB7IE1hcGFCdXR0b25Nb2R1bGUgfSBmcm9tIFwiLi4vLi4vLi4vLi4vLi4vZmlsdGVyc1wiO1xuaW1wb3J0IHsgTWFwYUNhcGFiaWxpdHlJbnRlcnZhbE1vZHVsZSB9IGZyb20gXCIuLi9jYXBhYmlsaXR5LWludGVydmFsL2NhcGFiaWxpdHktaW50ZXJ2YWwubW9kdWxlXCI7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW01hcGFDYXBhYmlsaXR5SW50ZXJ2YWxCYXJDb21wb25lbnRdLFxuICBleHBvcnRzOiBbTWFwYUNhcGFiaWxpdHlJbnRlcnZhbEJhckNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hcGFCdXR0b25Nb2R1bGUsIE1hcGFDYXBhYmlsaXR5SW50ZXJ2YWxNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXBhQ2FwYWJpbGl0eUludGVydmFsQmFyTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { NavigationStart } from "@angular/router";
|
|
3
|
+
import { MapaCapabilityIntervalBarComponent } from "../capability-interval-bar/capability-interval-bar.component";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/router";
|
|
6
|
+
export class ReusableCapabilityIntervalBarService {
|
|
7
|
+
constructor(componentFactoryResolver, injector, router) {
|
|
8
|
+
this.componentFactoryResolver = componentFactoryResolver;
|
|
9
|
+
this.injector = injector;
|
|
10
|
+
this.router = router;
|
|
11
|
+
const componentFactory = this.componentFactoryResolver.resolveComponentFactory(MapaCapabilityIntervalBarComponent);
|
|
12
|
+
this.componentRef = componentFactory.create(injector);
|
|
13
|
+
this.router.events.subscribe((event) => {
|
|
14
|
+
if (event instanceof NavigationStart && this.currentViewContainerRef) {
|
|
15
|
+
this.detach(this.currentViewContainerRef);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
attach(viewContainerRef) {
|
|
20
|
+
this.currentViewContainerRef = viewContainerRef;
|
|
21
|
+
viewContainerRef.insert(this.componentRef.hostView);
|
|
22
|
+
}
|
|
23
|
+
detach(viewContainerRef) {
|
|
24
|
+
viewContainerRef.detach(viewContainerRef.indexOf(this.componentRef.hostView));
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
ReusableCapabilityIntervalBarService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ReusableCapabilityIntervalBarService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
28
|
+
ReusableCapabilityIntervalBarService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ReusableCapabilityIntervalBarService });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ReusableCapabilityIntervalBarService, decorators: [{
|
|
30
|
+
type: Injectable
|
|
31
|
+
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.Injector }, { type: i1.Router }]; } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmV1c2FibGUtaW50ZXJ2YWwtYmFyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb21wb25lbnRzL2NhcGFiaWxpdHkvc3JjL3NlcnZpY2VzL3JldXNhYmxlLWludGVydmFsLWJhci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFLTCxVQUFVLEVBQ1gsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFVLGVBQWUsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzFELE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLDhEQUE4RCxDQUFDOzs7QUFHbEgsTUFBTSxPQUFPLG9DQUFvQztJQUsvQyxZQUNVLHdCQUFrRCxFQUNsRCxRQUFrQixFQUNsQixNQUFjO1FBRmQsNkJBQXdCLEdBQXhCLHdCQUF3QixDQUEwQjtRQUNsRCxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQ2xCLFdBQU0sR0FBTixNQUFNLENBQVE7UUFFdEIsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsd0JBQXdCLENBQUMsdUJBQXVCLENBQzVFLGtDQUFrQyxDQUNuQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLFlBQVksR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFdEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDckMsSUFBSSxLQUFLLFlBQVksZUFBZSxJQUFJLElBQUksQ0FBQyx1QkFBdUIsRUFBRTtnQkFDcEUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsQ0FBQzthQUMzQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLE1BQU0sQ0FBQyxnQkFBa0M7UUFDOUMsSUFBSSxDQUFDLHVCQUF1QixHQUFHLGdCQUFnQixDQUFDO1FBQ2hELGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFTSxNQUFNLENBQUMsZ0JBQWtDO1FBQzlDLGdCQUFnQixDQUFDLE1BQU0sQ0FDckIsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQ3JELENBQUM7SUFDSixDQUFDOztrSUEvQlUsb0NBQW9DO3NJQUFwQyxvQ0FBb0M7NEZBQXBDLG9DQUFvQztrQkFEaEQsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudFJlZixcbiAgVmlld0NvbnRhaW5lclJlZixcbiAgQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxuICBJbmplY3RvcixcbiAgSW5qZWN0YWJsZVxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgUm91dGVyLCBOYXZpZ2F0aW9uU3RhcnQgfSBmcm9tIFwiQGFuZ3VsYXIvcm91dGVyXCI7XG5pbXBvcnQgeyBNYXBhQ2FwYWJpbGl0eUludGVydmFsQmFyQ29tcG9uZW50IH0gZnJvbSBcIi4uL2NhcGFiaWxpdHktaW50ZXJ2YWwtYmFyL2NhcGFiaWxpdHktaW50ZXJ2YWwtYmFyLmNvbXBvbmVudFwiO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgUmV1c2FibGVDYXBhYmlsaXR5SW50ZXJ2YWxCYXJTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBjb21wb25lbnRSZWY6IENvbXBvbmVudFJlZjxNYXBhQ2FwYWJpbGl0eUludGVydmFsQmFyQ29tcG9uZW50PjtcblxuICBwcml2YXRlIGN1cnJlbnRWaWV3Q29udGFpbmVyUmVmITogVmlld0NvbnRhaW5lclJlZjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGNvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxuICAgIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yLFxuICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXJcbiAgKSB7XG4gICAgY29uc3QgY29tcG9uZW50RmFjdG9yeSA9IHRoaXMuY29tcG9uZW50RmFjdG9yeVJlc29sdmVyLnJlc29sdmVDb21wb25lbnRGYWN0b3J5KFxuICAgICAgTWFwYUNhcGFiaWxpdHlJbnRlcnZhbEJhckNvbXBvbmVudFxuICAgICk7XG4gICAgdGhpcy5jb21wb25lbnRSZWYgPSBjb21wb25lbnRGYWN0b3J5LmNyZWF0ZShpbmplY3Rvcik7XG5cbiAgICB0aGlzLnJvdXRlci5ldmVudHMuc3Vic2NyaWJlKChldmVudCkgPT4ge1xuICAgICAgaWYgKGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvblN0YXJ0ICYmIHRoaXMuY3VycmVudFZpZXdDb250YWluZXJSZWYpIHtcbiAgICAgICAgdGhpcy5kZXRhY2godGhpcy5jdXJyZW50Vmlld0NvbnRhaW5lclJlZik7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgYXR0YWNoKHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHtcbiAgICB0aGlzLmN1cnJlbnRWaWV3Q29udGFpbmVyUmVmID0gdmlld0NvbnRhaW5lclJlZjtcbiAgICB2aWV3Q29udGFpbmVyUmVmLmluc2VydCh0aGlzLmNvbXBvbmVudFJlZi5ob3N0Vmlldyk7XG4gIH1cblxuICBwdWJsaWMgZGV0YWNoKHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHtcbiAgICB2aWV3Q29udGFpbmVyUmVmLmRldGFjaChcbiAgICAgIHZpZXdDb250YWluZXJSZWYuaW5kZXhPZih0aGlzLmNvbXBvbmVudFJlZi5ob3N0VmlldylcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -17,6 +17,7 @@ export class MapaTableComponent {
|
|
|
17
17
|
this.data = [];
|
|
18
18
|
this.tableData = new EventEmitter();
|
|
19
19
|
this.rowClick = new EventEmitter();
|
|
20
|
+
this.selectedObjectsChange = new EventEmitter();
|
|
20
21
|
this.displayedColumns = [];
|
|
21
22
|
this.selection = new SelectionModel(true, []);
|
|
22
23
|
}
|
|
@@ -80,18 +81,18 @@ export class MapaTableComponent {
|
|
|
80
81
|
});
|
|
81
82
|
return obj;
|
|
82
83
|
});
|
|
83
|
-
this.
|
|
84
|
-
this.cdr.detectChanges();
|
|
84
|
+
this.selectedObjectsChange.emit(selectedObjects);
|
|
85
85
|
}
|
|
86
|
-
handleRowClick(id) {
|
|
86
|
+
handleRowClick(id, test) {
|
|
87
|
+
console.log(test);
|
|
87
88
|
this.rowClick.emit(id);
|
|
88
89
|
}
|
|
89
90
|
}
|
|
90
91
|
MapaTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaTableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
91
|
-
MapaTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MapaTableComponent, selector: "mapa-table", inputs: { columns: "columns", data: "data", checkbox: "checkbox", actions: "actions" }, outputs: { tableData: "tableData", rowClick: "rowClick" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true }], ngImport: i0, template: "<div class=\"
|
|
92
|
+
MapaTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MapaTableComponent, selector: "mapa-table", inputs: { columns: "columns", data: "data", checkbox: "checkbox", actions: "actions" }, outputs: { tableData: "tableData", rowClick: "rowClick", selectedObjectsChange: "selectedObjectsChange" }, viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }, { propertyName: "sort", first: true, predicate: MatSort, descendants: true }], ngImport: i0, template: "<div class=\"table\">\n <table mat-table [dataSource]=\"dataSource\" matSort>\n <ng-container *ngFor=\"let column of columns; let isFirst = first\" [matColumnDef]=\"column.key\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header (click)=\"sortData(column.key)\">\n <div class=\"header\">\n <ng-container *ngIf=\"isFirst && checkbox\">\n <mat-checkbox (change)=\"$event ? toggleAllRows() : null\" [checked]=\"selection.hasValue() && isAllSelected()\"\n [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\n (click)=\"$event.stopPropagation(); createObjectFromSelection()\">\n </mat-checkbox>\n </ng-container>\n <div *ngIf=\"column.key !== 'actions'\">\n <mat-icon>filter_list</mat-icon>\n </div>\n <div class=\"label\">\n {{ column.label }}\n </div> \n </div> \n </th>\n <td mat-cell *matCellDef=\"let row\">\n <ng-container *ngIf=\"isFirst && checkbox\">\n <mat-checkbox (click)=\"$event.stopPropagation(); createObjectFromSelection()\"\n (change)=\"$event ? selection.toggle(row) : null\" [checked]=\"selection.isSelected(row)\">\n </mat-checkbox>\n </ng-container>\n <ng-container *ngIf=\"column.key === 'actions'\">\n <div class=\"actions\">\n <mat-icon (click)=\"handleRowClick(row, 'edit')\">edit</mat-icon>\n <mat-icon (click)=\"handleRowClick(row, 'delete')\">delete</mat-icon> \n <mat-icon (click)=\"handleRowClick(row, 'visibility')\">visibility</mat-icon>\n </div>\n </ng-container>\n <div class=\"table__column\" (click)=\"handleRowClick(row, '')\">\n {{ row[column.key] }}\n </div>\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n </table>\n\n <mat-paginator class=\"custom_paginator\" appBubblePagination\n [appCustomLength]=\"dataSource ? dataSource.data.length : 0\" [length]=\"dataSource ? dataSource.data.length : 0\"\n [pageSizeOptions]=\"[5, 10, 25, 100]\" [pageSize]=\"5\" aria-label=\"Select page\"></mat-paginator>\n</div>", styles: [".table__column{width:100%}.table ::ng-deep .mat-mdc-paginator-page-size-label{display:none}.table .mat-table{width:100%}.table .tr,.table th{padding-top:15px;padding-bottom:15px}.table .label{margin-top:4px}.table .header{padding-top:15px;padding-bottom:15px;align-items:center;display:flex}.table .mat-mdc-cell{padding:15px}.table .mat-icon{cursor:pointer;position:relative;bottom:-6px;padding:0 5px}.table .actions{display:flex}.table .actions .mat-icon{color:#ea561d!important}.table .mat-accent{--mdc-checkbox-selected-focus-icon-color: #ea561d;--mdc-checkbox-selected-hover-icon-color: #ea561d;--mdc-checkbox-selected-pressed-icon-color: transparent;--mdc-checkbox-selected-icon-color: #ea561d;--mdc-checkbox-selected-checkmark-color: #fff;--mdc-circular-progress-active-indicator-color: transparent}.mat-mdc-paginator-container{display:flex;justify-content:space-between}.g-bubble-container{display:flex;gap:4px}.g-bubble{background-color:#fff;border-radius:20%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#181818;font-size:14px;cursor:pointer;transition:.3s}.g-bubble:hover{background-color:#b6b6b6;color:#fff}.g-bubble__active{background-color:#ea561d;color:#fff}mat-paginator{background:transparent!important}.mat-mdc-paginator-range-actions{margin-right:12px!important}.custom_paginator .mat-mdc-paginator-container{display:flex;justify-content:space-between;margin-right:25vw}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i5.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i5.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i5.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i5.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i5.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i5.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i5.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i5.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i5.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i5.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i6.BubblePaginationDirective, selector: "[appBubblePagination]", inputs: ["showFirstButton", "showLastButton", "renderButtonsNumber", "appCustomLength", "hideDefaultArrows"], outputs: ["pageIndexChangeEmitter"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
92
93
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaTableComponent, decorators: [{
|
|
93
94
|
type: Component,
|
|
94
|
-
args: [{ selector: 'mapa-table', encapsulation: ViewEncapsulation.None, template: "<div class=\"
|
|
95
|
+
args: [{ selector: 'mapa-table', encapsulation: ViewEncapsulation.None, template: "<div class=\"table\">\n <table mat-table [dataSource]=\"dataSource\" matSort>\n <ng-container *ngFor=\"let column of columns; let isFirst = first\" [matColumnDef]=\"column.key\">\n <th mat-header-cell *matHeaderCellDef mat-sort-header (click)=\"sortData(column.key)\">\n <div class=\"header\">\n <ng-container *ngIf=\"isFirst && checkbox\">\n <mat-checkbox (change)=\"$event ? toggleAllRows() : null\" [checked]=\"selection.hasValue() && isAllSelected()\"\n [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\n (click)=\"$event.stopPropagation(); createObjectFromSelection()\">\n </mat-checkbox>\n </ng-container>\n <div *ngIf=\"column.key !== 'actions'\">\n <mat-icon>filter_list</mat-icon>\n </div>\n <div class=\"label\">\n {{ column.label }}\n </div> \n </div> \n </th>\n <td mat-cell *matCellDef=\"let row\">\n <ng-container *ngIf=\"isFirst && checkbox\">\n <mat-checkbox (click)=\"$event.stopPropagation(); createObjectFromSelection()\"\n (change)=\"$event ? selection.toggle(row) : null\" [checked]=\"selection.isSelected(row)\">\n </mat-checkbox>\n </ng-container>\n <ng-container *ngIf=\"column.key === 'actions'\">\n <div class=\"actions\">\n <mat-icon (click)=\"handleRowClick(row, 'edit')\">edit</mat-icon>\n <mat-icon (click)=\"handleRowClick(row, 'delete')\">delete</mat-icon> \n <mat-icon (click)=\"handleRowClick(row, 'visibility')\">visibility</mat-icon>\n </div>\n </ng-container>\n <div class=\"table__column\" (click)=\"handleRowClick(row, '')\">\n {{ row[column.key] }}\n </div>\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n </table>\n\n <mat-paginator class=\"custom_paginator\" appBubblePagination\n [appCustomLength]=\"dataSource ? dataSource.data.length : 0\" [length]=\"dataSource ? dataSource.data.length : 0\"\n [pageSizeOptions]=\"[5, 10, 25, 100]\" [pageSize]=\"5\" aria-label=\"Select page\"></mat-paginator>\n</div>", styles: [".table__column{width:100%}.table ::ng-deep .mat-mdc-paginator-page-size-label{display:none}.table .mat-table{width:100%}.table .tr,.table th{padding-top:15px;padding-bottom:15px}.table .label{margin-top:4px}.table .header{padding-top:15px;padding-bottom:15px;align-items:center;display:flex}.table .mat-mdc-cell{padding:15px}.table .mat-icon{cursor:pointer;position:relative;bottom:-6px;padding:0 5px}.table .actions{display:flex}.table .actions .mat-icon{color:#ea561d!important}.table .mat-accent{--mdc-checkbox-selected-focus-icon-color: #ea561d;--mdc-checkbox-selected-hover-icon-color: #ea561d;--mdc-checkbox-selected-pressed-icon-color: transparent;--mdc-checkbox-selected-icon-color: #ea561d;--mdc-checkbox-selected-checkmark-color: #fff;--mdc-circular-progress-active-indicator-color: transparent}.mat-mdc-paginator-container{display:flex;justify-content:space-between}.g-bubble-container{display:flex;gap:4px}.g-bubble{background-color:#fff;border-radius:20%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#181818;font-size:14px;cursor:pointer;transition:.3s}.g-bubble:hover{background-color:#b6b6b6;color:#fff}.g-bubble__active{background-color:#ea561d;color:#fff}mat-paginator{background:transparent!important}.mat-mdc-paginator-range-actions{margin-right:12px!important}.custom_paginator .mat-mdc-paginator-container{display:flex;justify-content:space-between;margin-right:25vw}\n"] }]
|
|
95
96
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { columns: [{
|
|
96
97
|
type: Input
|
|
97
98
|
}], data: [{
|
|
@@ -110,5 +111,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
110
111
|
type: Output
|
|
111
112
|
}], rowClick: [{
|
|
112
113
|
type: Output
|
|
114
|
+
}], selectedObjectsChange: [{
|
|
115
|
+
type: Output
|
|
113
116
|
}] } });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/mapa-library-ui/src/lib/components/table/src/table.component.ts","../../../../../../../../projects/mapa-library-ui/src/lib/components/table/src/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { MatPaginator } from '@angular/material/paginator';\nimport { MatSort, Sort } from '@angular/material/sort';\nimport { MatTableDataSource } from '@angular/material/table';\n\n@Component({\n  selector: 'mapa-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class MapaTableComponent {\n  @Input() columns: TableColumn[] = [];\n  @Input() data: Object[] = [];\n  @Input() checkbox: boolean | undefined; \n  @Input() actions: boolean | undefined;\n  @ViewChild(MatPaginator) paginator!: MatPaginator;\n  @ViewChild(MatSort) sort!: MatSort;\n  @Output() tableData: EventEmitter<any[]> = new EventEmitter<any[]>();\n  @Output() rowClick: EventEmitter<string> = new EventEmitter<string>(); \n  dataSource!: MatTableDataSource<Object>;\n  displayedColumns: string[] = [];\n  currentSort: Sort | undefined;\n  selection = new SelectionModel<any>(true, []);\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngAfterViewInit() {\n    this.dataSource = new MatTableDataSource(this.data);\n    this.dataSource.paginator = this.paginator;\n    this.dataSource.sort = this.sort;\n    this.displayedColumns = this.columns.map(column => column.key);\n  }\n\n  isAllSelected() {\n    const numSelected = this.selection.selected.length;\n    const numRows = this.dataSource.data.length;\n    return numSelected === numRows;\n  }\n\n  toggleAllRows() {\n    if (this.isAllSelected()) {\n      this.selection.clear();\n    } else {\n      const dataAsPeriodicElements = this.dataSource.data as any[];\n      dataAsPeriodicElements.forEach(row => this.selection.select(row));\n    }\n  }\n\n  checkboxLabel(row?: any): string {\n    if (!row) {\n      return `${this.isAllSelected() ? 'deselect' : 'select'} all`;\n    }\n    return `${this.selection.isSelected(row) ? 'deselect' : 'select'} row ${row.position + 1}`;\n  }\n\n  sortData(sortKey: string) {\n    const sort: Sort = { active: sortKey, direction: 'asc' };\n\n    if (this.currentSort && this.currentSort.active === sortKey && this.currentSort.direction === 'asc') {\n      sort.direction = 'desc';\n    }\n\n    this.currentSort = sort;\n    this.sortDataFunction(sort);\n  }\n\n  sortDataFunction(sort: Sort) {\n    const data = this.dataSource.data.slice();\n\n    if (!sort.active || sort.direction === '') {\n      this.dataSource.data = data;\n      return;\n    }\n\n    this.dataSource.data = data.sort((a: any, b: any) => {\n      const isAsc = sort.direction === 'asc';\n      return this.compare(a[sort.active], b[sort.active], isAsc);\n    });\n  }\n\n  compare(a: any, b: any, isAsc: boolean) {\n    if (typeof a === 'string' && typeof b === 'string') {\n      return (a.toLowerCase() < b.toLowerCase() ? -1 : 1) * (isAsc ? 1 : -1);\n    }\n    return (a < b ? -1 : 1) * (isAsc ? 1 : -1);\n  }\n\n  createObjectFromSelection() {\n    const selectedRows = this.selection.selected;\n    const selectedObjects = selectedRows.map(row => {\n      const obj: any = {};\n      this.columns.forEach(column => {\n        obj[column.key] = row[column.key];\n      });\n      return obj;\n    });\n    this.tableData.emit(selectedObjects);\n    this.cdr.detectChanges();\n  }\n\n  handleRowClick(id: string) {\n    this.rowClick.emit(id); \n  }\n}\n\nexport interface TableColumn {\n  key: string;\n  label: string;\n  sort: boolean;\n}\n","<div class=\"checkboxTable\">\n  <table mat-table [dataSource]=\"dataSource\" matSort>\n    <ng-container *ngFor=\"let column of columns; let isFirst = first\" [matColumnDef]=\"column.key\">\n      <th mat-header-cell *matHeaderCellDef mat-sort-header (click)=\"sortData(column.key)\">\n        <div class=\"header\">\n          <ng-container *ngIf=\"isFirst && checkbox\">\n            <mat-checkbox (change)=\"$event ? toggleAllRows() : null\" [checked]=\"selection.hasValue() && isAllSelected()\"\n              [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\n              (click)=\"$event.stopPropagation(); createObjectFromSelection()\">\n            </mat-checkbox>\n          </ng-container>\n          <div *ngIf=\"column.key !== 'actions'\">\n            <mat-icon>filter_list</mat-icon>\n          </div>\n          <div class=\"label\">\n            {{ column.label }}\n          </div> \n        </div> \n      </th>\n      <td mat-cell *matCellDef=\"let row\">\n        <ng-container *ngIf=\"isFirst && checkbox\">\n          <mat-checkbox (click)=\"$event.stopPropagation(); createObjectFromSelection()\"\n            (change)=\"$event ? selection.toggle(row) : null\" [checked]=\"selection.isSelected(row)\">\n          </mat-checkbox>\n        </ng-container>\n        <ng-container *ngIf=\"column.key === 'actions'\">\n          <div class=\"actions\">\n            <mat-icon (click)=\"handleRowClick(row)\">edit</mat-icon>\n            <mat-icon (click)=\"handleRowClick(row)\">delete</mat-icon>          \n            <mat-icon (click)=\"handleRowClick(row)\">visibility</mat-icon>\n          </div>\n        </ng-container>\n        {{ row[column.key] }}\n      </td>\n    </ng-container>\n\n    <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n  </table>\n\n  <mat-paginator class=\"custom_paginator\" appBubblePagination\n    [appCustomLength]=\"dataSource ? dataSource.data.length : 0\" [length]=\"dataSource ? dataSource.data.length : 0\"\n    [pageSizeOptions]=\"[5, 10, 25, 100]\" [pageSize]=\"5\" aria-label=\"Select page\"></mat-paginator>\n</div>"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/mapa-library-ui/src/lib/components/table/src/table.component.ts","../../../../../../../../projects/mapa-library-ui/src/lib/components/table/src/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { MatPaginator } from '@angular/material/paginator';\nimport { MatSort, Sort } from '@angular/material/sort';\nimport { MatTableDataSource } from '@angular/material/table';\n\n@Component({\n  selector: 'mapa-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class MapaTableComponent {\n  @Input() columns: TableColumn[] = [];\n  @Input() data: Object[] = [];\n  @Input() checkbox: boolean | undefined; \n  @Input() actions: boolean | undefined;\n  @ViewChild(MatPaginator) paginator!: MatPaginator;\n  @ViewChild(MatSort) sort!: MatSort;\n  @Output() tableData: EventEmitter<any[]> = new EventEmitter<any[]>();\n  @Output() rowClick: EventEmitter<string> = new EventEmitter<string>(); \n  @Output() selectedObjectsChange: EventEmitter<any[]> = new EventEmitter<any[]>();\n\n  dataSource!: MatTableDataSource<Object>;\n  displayedColumns: string[] = [];\n  currentSort: Sort | undefined;\n  selection = new SelectionModel<any>(true, []);\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngAfterViewInit() {\n    this.dataSource = new MatTableDataSource(this.data);\n    this.dataSource.paginator = this.paginator;\n    this.dataSource.sort = this.sort;\n    this.displayedColumns = this.columns.map(column => column.key);\n  }\n\n  isAllSelected() {\n    const numSelected = this.selection.selected.length;\n    const numRows = this.dataSource.data.length;\n    return numSelected === numRows;\n  }\n\n  toggleAllRows() {\n    if (this.isAllSelected()) {\n      this.selection.clear();\n    } else {\n      const dataAsPeriodicElements = this.dataSource.data as any[];\n      dataAsPeriodicElements.forEach(row => this.selection.select(row));\n    }\n  }\n\n  checkboxLabel(row?: any): string {\n    if (!row) {\n      return `${this.isAllSelected() ? 'deselect' : 'select'} all`;\n    }\n    return `${this.selection.isSelected(row) ? 'deselect' : 'select'} row ${row.position + 1}`;\n  }\n\n  sortData(sortKey: string) {\n    const sort: Sort = { active: sortKey, direction: 'asc' };\n\n    if (this.currentSort && this.currentSort.active === sortKey && this.currentSort.direction === 'asc') {\n      sort.direction = 'desc';\n    }\n\n    this.currentSort = sort;\n    this.sortDataFunction(sort);\n  }\n\n  sortDataFunction(sort: Sort) {\n    const data = this.dataSource.data.slice();\n\n    if (!sort.active || sort.direction === '') {\n      this.dataSource.data = data;\n      return;\n    }\n\n    this.dataSource.data = data.sort((a: any, b: any) => {\n      const isAsc = sort.direction === 'asc';\n      return this.compare(a[sort.active], b[sort.active], isAsc);\n    });\n  }\n\n  compare(a: any, b: any, isAsc: boolean) {\n    if (typeof a === 'string' && typeof b === 'string') {\n      return (a.toLowerCase() < b.toLowerCase() ? -1 : 1) * (isAsc ? 1 : -1);\n    }\n    return (a < b ? -1 : 1) * (isAsc ? 1 : -1);\n  }\n\n  createObjectFromSelection() {\n  const selectedRows = this.selection.selected;\n  const selectedObjects = selectedRows.map(row => {\n    const obj: any = {};\n    this.columns.forEach(column => {\n      obj[column.key] = row[column.key];\n    });\n    return obj;\n  });\n  this.selectedObjectsChange.emit(selectedObjects);\n}\n\n  handleRowClick(id: string, test: string) {\n    console.log(test);\n    this.rowClick.emit(id); \n  }\n}\n\nexport interface TableColumn {\n  key: string;\n  label: string;\n  sort: boolean;\n}\n","<div class=\"table\">\n  <table mat-table [dataSource]=\"dataSource\" matSort>\n    <ng-container *ngFor=\"let column of columns; let isFirst = first\" [matColumnDef]=\"column.key\">\n      <th mat-header-cell *matHeaderCellDef mat-sort-header (click)=\"sortData(column.key)\">\n        <div class=\"header\">\n          <ng-container *ngIf=\"isFirst && checkbox\">\n            <mat-checkbox (change)=\"$event ? toggleAllRows() : null\" [checked]=\"selection.hasValue() && isAllSelected()\"\n              [indeterminate]=\"selection.hasValue() && !isAllSelected()\"\n              (click)=\"$event.stopPropagation(); createObjectFromSelection()\">\n            </mat-checkbox>\n          </ng-container>\n          <div *ngIf=\"column.key !== 'actions'\">\n            <mat-icon>filter_list</mat-icon>\n          </div>\n          <div class=\"label\">\n            {{ column.label }}\n          </div> \n        </div> \n      </th>\n      <td mat-cell *matCellDef=\"let row\">\n        <ng-container *ngIf=\"isFirst && checkbox\">\n          <mat-checkbox (click)=\"$event.stopPropagation(); createObjectFromSelection()\"\n            (change)=\"$event ? selection.toggle(row) : null\" [checked]=\"selection.isSelected(row)\">\n          </mat-checkbox>\n        </ng-container>\n        <ng-container *ngIf=\"column.key === 'actions'\">\n          <div class=\"actions\">\n            <mat-icon (click)=\"handleRowClick(row, 'edit')\">edit</mat-icon>\n            <mat-icon (click)=\"handleRowClick(row, 'delete')\">delete</mat-icon>          \n            <mat-icon (click)=\"handleRowClick(row, 'visibility')\">visibility</mat-icon>\n          </div>\n        </ng-container>\n        <div class=\"table__column\" (click)=\"handleRowClick(row, '')\">\n          {{ row[column.key] }}\n        </div>\n      </td>\n    </ng-container>\n\n    <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n  </table>\n\n  <mat-paginator class=\"custom_paginator\" appBubblePagination\n    [appCustomLength]=\"dataSource ? dataSource.data.length : 0\" [length]=\"dataSource ? dataSource.data.length : 0\"\n    [pageSizeOptions]=\"[5, 10, 25, 100]\" [pageSize]=\"5\" aria-label=\"Select page\"></mat-paginator>\n</div>"]}
|