@senior-gestao-empresarial/angular-components 7.19.0 → 7.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/bundles/senior-gestao-empresarial-angular-components.umd.js +843 -220
  2. package/bundles/senior-gestao-empresarial-angular-components.umd.js.map +1 -1
  3. package/bundles/senior-gestao-empresarial-angular-components.umd.min.js +2 -2
  4. package/bundles/senior-gestao-empresarial-angular-components.umd.min.js.map +1 -1
  5. package/components/object-card/elements/field/object-card-field.component.d.ts +18 -0
  6. package/components/object-card/elements/main/object-card-main.component.d.ts +37 -0
  7. package/components/object-card/index.d.ts +4 -0
  8. package/components/object-card/object-card.component.d.ts +29 -0
  9. package/components/object-card/object-card.module.d.ts +2 -0
  10. package/components/shared/border-button/border-button.component.d.ts +7 -0
  11. package/components/shared/border-button/border-button.module.d.ts +2 -0
  12. package/components/shared/models/border-button-options.d.ts +9 -0
  13. package/components/shared/models/enum-severity.d.ts +7 -0
  14. package/components/thumbnail/index.d.ts +3 -0
  15. package/components/thumbnail/thumbnail-size.d.ts +5 -0
  16. package/components/thumbnail/thumbnail.component.d.ts +28 -0
  17. package/components/thumbnail/thumbnail.module.d.ts +2 -0
  18. package/components/thumbnail/thumbnail.service.d.ts +21 -0
  19. package/esm2015/components/object-card/elements/field/object-card-field.component.js +58 -0
  20. package/esm2015/components/object-card/elements/main/object-card-main.component.js +142 -0
  21. package/esm2015/components/object-card/index.js +5 -0
  22. package/esm2015/components/object-card/object-card.component.js +142 -0
  23. package/esm2015/components/object-card/object-card.module.js +22 -0
  24. package/esm2015/components/shared/border-button/border-button.component.js +24 -0
  25. package/esm2015/components/shared/border-button/border-button.module.js +16 -0
  26. package/esm2015/components/shared/models/border-button-options.js +1 -0
  27. package/esm2015/components/shared/models/enum-severity.js +9 -0
  28. package/esm2015/components/thumbnail/index.js +4 -0
  29. package/esm2015/components/thumbnail/thumbnail-size.js +7 -0
  30. package/esm2015/components/thumbnail/thumbnail.component.js +96 -0
  31. package/esm2015/components/thumbnail/thumbnail.module.js +17 -0
  32. package/esm2015/components/thumbnail/thumbnail.service.js +90 -0
  33. package/esm2015/public-api.js +3 -1
  34. package/esm2015/senior-gestao-empresarial-angular-components.js +8 -5
  35. package/esm5/components/object-card/elements/field/object-card-field.component.js +60 -0
  36. package/esm5/components/object-card/elements/main/object-card-main.component.js +167 -0
  37. package/esm5/components/object-card/index.js +5 -0
  38. package/esm5/components/object-card/object-card.component.js +144 -0
  39. package/esm5/components/object-card/object-card.module.js +25 -0
  40. package/esm5/components/shared/border-button/border-button.component.js +25 -0
  41. package/esm5/components/shared/border-button/border-button.module.js +19 -0
  42. package/esm5/components/shared/models/border-button-options.js +1 -0
  43. package/esm5/components/shared/models/enum-severity.js +9 -0
  44. package/esm5/components/thumbnail/index.js +4 -0
  45. package/esm5/components/thumbnail/thumbnail-size.js +7 -0
  46. package/esm5/components/thumbnail/thumbnail.component.js +99 -0
  47. package/esm5/components/thumbnail/thumbnail.module.js +20 -0
  48. package/esm5/components/thumbnail/thumbnail.service.js +95 -0
  49. package/esm5/public-api.js +3 -1
  50. package/esm5/senior-gestao-empresarial-angular-components.js +8 -5
  51. package/fesm2015/senior-gestao-empresarial-angular-components.js +737 -167
  52. package/fesm2015/senior-gestao-empresarial-angular-components.js.map +1 -1
  53. package/fesm5/senior-gestao-empresarial-angular-components.js +835 -218
  54. package/fesm5/senior-gestao-empresarial-angular-components.js.map +1 -1
  55. package/package.json +1 -1
  56. package/public-api.d.ts +2 -0
  57. package/senior-gestao-empresarial-angular-components.d.ts +7 -4
  58. package/senior-gestao-empresarial-angular-components.metadata.json +1 -1
@@ -0,0 +1,167 @@
1
+ import { __awaiter, __decorate, __generator } from "tslib";
2
+ import { Component, ContentChild, EventEmitter, HostListener, Input, Output } from "@angular/core";
3
+ import { ThumbnailSize } from "../../../thumbnail/thumbnail-size";
4
+ import { ThumbnailComponent } from "../../../thumbnail/thumbnail.component";
5
+ import { Breakpoints } from "../../../utils";
6
+ var ObjectCardMainComponent = /** @class */ (function () {
7
+ function ObjectCardMainComponent() {
8
+ this.id = "erp-object-card-main-" + ObjectCardMainComponent_1.getNextId();
9
+ this.iconClass = "fa fa-picture-o";
10
+ this.hasThumbnail = true;
11
+ this.hasDescription = true;
12
+ this.isBrand = false;
13
+ this.expandableImage = false;
14
+ this.buttonClick = new EventEmitter();
15
+ this.showImageModal = false;
16
+ this.loadingFullImage = false;
17
+ this._thumbnailSize = ThumbnailSize.Medium;
18
+ }
19
+ ObjectCardMainComponent_1 = ObjectCardMainComponent;
20
+ Object.defineProperty(ObjectCardMainComponent.prototype, "thumbnailSize", {
21
+ get: function () {
22
+ return this._thumbnailSize;
23
+ },
24
+ set: function (value) {
25
+ this._thumbnailSize = value;
26
+ if (this.thumbnailComponent) {
27
+ this.thumbnailComponent.size = value;
28
+ }
29
+ },
30
+ enumerable: true,
31
+ configurable: true
32
+ });
33
+ ObjectCardMainComponent.prototype.onResize = function () {
34
+ this.update();
35
+ };
36
+ ObjectCardMainComponent.prototype.ngAfterContentInit = function () {
37
+ this.update();
38
+ };
39
+ ObjectCardMainComponent.prototype.update = function () {
40
+ var windowWidth = window.innerWidth;
41
+ if (windowWidth <= Breakpoints.SM_MAX) {
42
+ this.thumbnailSize = ThumbnailSize.Small;
43
+ }
44
+ else {
45
+ this.thumbnailSize = ThumbnailSize.Medium;
46
+ }
47
+ };
48
+ ObjectCardMainComponent.getNextId = function () {
49
+ var id = ObjectCardMainComponent_1.nextId;
50
+ ObjectCardMainComponent_1.nextId++;
51
+ return id;
52
+ };
53
+ ObjectCardMainComponent.prototype.getImageAltText = function () {
54
+ var altText = this.imageAlt || this.label || '';
55
+ return altText.replace(/\bimage\b/gi, '').replace(/\bimagem\b/gi, '').trim();
56
+ };
57
+ ObjectCardMainComponent.prototype.openImageModal = function () {
58
+ return __awaiter(this, void 0, void 0, function () {
59
+ var _a;
60
+ return __generator(this, function (_b) {
61
+ switch (_b.label) {
62
+ case 0:
63
+ if (!this.expandableImage || !this.imageSource) {
64
+ return [2 /*return*/];
65
+ }
66
+ this.showImageModal = true;
67
+ _a = this;
68
+ return [4 /*yield*/, this.resolveFullImageSource()];
69
+ case 1:
70
+ _a.fullImageSource = _b.sent();
71
+ return [2 /*return*/];
72
+ }
73
+ });
74
+ });
75
+ };
76
+ ObjectCardMainComponent.prototype.resolveFullImageSource = function () {
77
+ return __awaiter(this, void 0, void 0, function () {
78
+ var result, error_1;
79
+ return __generator(this, function (_a) {
80
+ switch (_a.label) {
81
+ case 0:
82
+ if (!this.imageLoader || this.fullImageSource) {
83
+ return [2 /*return*/, this.fullImageSource || this.imageSource];
84
+ }
85
+ this.loadingFullImage = true;
86
+ _a.label = 1;
87
+ case 1:
88
+ _a.trys.push([1, 3, 4, 5]);
89
+ result = this.imageLoader();
90
+ return [4 /*yield*/, (result instanceof Promise ? result : result.toPromise())];
91
+ case 2: return [2 /*return*/, _a.sent()];
92
+ case 3:
93
+ error_1 = _a.sent();
94
+ console.error('Erro ao carregar imagem completa:', error_1);
95
+ return [2 /*return*/, this.imageSource];
96
+ case 4:
97
+ this.loadingFullImage = false;
98
+ return [7 /*endfinally*/];
99
+ case 5: return [2 /*return*/];
100
+ }
101
+ });
102
+ });
103
+ };
104
+ var ObjectCardMainComponent_1;
105
+ ObjectCardMainComponent.nextId = 0;
106
+ __decorate([
107
+ Input()
108
+ ], ObjectCardMainComponent.prototype, "id", void 0);
109
+ __decorate([
110
+ Input()
111
+ ], ObjectCardMainComponent.prototype, "imageSource", void 0);
112
+ __decorate([
113
+ Input()
114
+ ], ObjectCardMainComponent.prototype, "imageFallback", void 0);
115
+ __decorate([
116
+ Input()
117
+ ], ObjectCardMainComponent.prototype, "imageAlt", void 0);
118
+ __decorate([
119
+ Input()
120
+ ], ObjectCardMainComponent.prototype, "iconClass", void 0);
121
+ __decorate([
122
+ Input()
123
+ ], ObjectCardMainComponent.prototype, "hasThumbnail", void 0);
124
+ __decorate([
125
+ Input()
126
+ ], ObjectCardMainComponent.prototype, "hasDescription", void 0);
127
+ __decorate([
128
+ Input()
129
+ ], ObjectCardMainComponent.prototype, "isBrand", void 0);
130
+ __decorate([
131
+ Input()
132
+ ], ObjectCardMainComponent.prototype, "expandableImage", void 0);
133
+ __decorate([
134
+ Input()
135
+ ], ObjectCardMainComponent.prototype, "imageLoader", void 0);
136
+ __decorate([
137
+ Input()
138
+ ], ObjectCardMainComponent.prototype, "label", void 0);
139
+ __decorate([
140
+ Input()
141
+ ], ObjectCardMainComponent.prototype, "description", void 0);
142
+ __decorate([
143
+ Input()
144
+ ], ObjectCardMainComponent.prototype, "buttonLabel", void 0);
145
+ __decorate([
146
+ Input()
147
+ ], ObjectCardMainComponent.prototype, "buttonModel", void 0);
148
+ __decorate([
149
+ Output()
150
+ ], ObjectCardMainComponent.prototype, "buttonClick", void 0);
151
+ __decorate([
152
+ ContentChild(ThumbnailComponent, { static: true })
153
+ ], ObjectCardMainComponent.prototype, "thumbnailComponent", void 0);
154
+ __decorate([
155
+ HostListener("window:resize")
156
+ ], ObjectCardMainComponent.prototype, "onResize", null);
157
+ ObjectCardMainComponent = ObjectCardMainComponent_1 = __decorate([
158
+ Component({
159
+ selector: "erp-object-card-main",
160
+ template: "<ng-container *ngIf=\"hasThumbnail\">\n <ng-content select=\"s-thumbnail\"></ng-content>\n <s-thumbnail\n [id]=\"id + '-thumbnail'\"\n [imageSource]=\"imageSource\"\n [imageFallback]=\"imageFallback\"\n [imageAlt]=\"imageAlt\"\n [iconClass]=\"iconClass\"\n [size]=\"thumbnailSize\"\n *ngIf=\"!thumbnailComponent\"\n [isBrand]=\"isBrand\"\n [ngClass]=\"{'expandable-thumbnail': expandableImage && imageSource}\"\n (click)=\"openImageModal()\"\n (keydown.enter)=\"openImageModal()\"\n (keydown.space)=\"openImageModal()\"\n tabindex=\"0\"\n role=\"button\"\n ></s-thumbnail>\n</ng-container>\n\n<p-dialog\n [header]=\"imageAlt || 'Visualizar'\"\n [(visible)]=\"showImageModal\"\n [modal]=\"true\"\n [dismissableMask]=\"true\"\n [styleClass]=\"'image-modal'\"\n [contentStyle]=\"{'overflow': 'auto', 'text-align': 'center'}\"\n>\n <s-loading-state [loading]=\"loadingFullImage\">\n <img\n *ngIf=\"fullImageSource\"\n [src]=\"fullImageSource\"\n alt=\"\"\n [attr.alt]=\"getImageAltText()\"\n width=\"100%\"\n height=\"auto\"\n class=\"expanded-image\"\n />\n </s-loading-state>\n</p-dialog>\n\n<ng-container *ngIf=\"hasDescription\">\n <div class=\"info-container\">\n <div #labelTemplate><ng-content select=\"[labelTemplate]\"></ng-content></div>\n <ng-container *ngTemplateOutlet=\"textSpan; context: {\n elementId: id + '-label',\n text: label,\n cssClass: 'label',\n templateWrapper: labelTemplate\n }\"></ng-container>\n\n <div #descriptionTemplate><ng-content select=\"[descriptionTemplate]\"></ng-content></div>\n <ng-container *ngTemplateOutlet=\"textSpan; context: {\n elementId: id + '-description',\n text: description,\n cssClass: 'description',\n templateWrapper: descriptionTemplate\n }\"></ng-container>\n\n <s-button\n [id]=\"id + '-button'\"\n *ngIf=\"buttonLabel\"\n styleClass=\"object-card-button\"\n priority=\"link\"\n [label]=\"buttonLabel\"\n [model]=\"buttonModel\"\n size=\"small\"\n (onClick)=\"buttonClick.emit($event)\"\n ></s-button>\n\n <ng-template\n #textSpan\n let-elementId=\"elementId\"\n let-text=\"text\"\n let-cssClass=\"cssClass\"\n let-templateWrapper=\"templateWrapper\"\n >\n <span\n [id]=\"elementId\"\n *ngIf=\"!templateWrapper.children.length\"\n [class]=\"cssClass\"\n [pTooltip]=\"text\"\n tooltipPosition=\"top\"\n showDelay=\"500\"\n >{{ text }}</span>\n </ng-template>\n </div>\n</ng-container>\n",
161
+ styles: [":host{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;min-height:70px}.info-container{margin-left:10px;-ms-flex:1;flex:1}.info-container,.info-container span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.info-container .label{display:block;font-weight:700}.info-container .description{color:#999;display:block}@media (max-width:767px){.info-container,.info-container span{white-space:normal}}::ng-deep .expandable-thumbnail{cursor:pointer;transition:opacity .2s}::ng-deep .expandable-thumbnail:hover{opacity:.8}::ng-deep .image-modal .p-dialog{max-width:90vw;max-height:90vh}::ng-deep .image-modal .expanded-image{max-width:80vw;max-height:80vh;width:auto;height:auto;object-fit:contain}"]
162
+ })
163
+ ], ObjectCardMainComponent);
164
+ return ObjectCardMainComponent;
165
+ }());
166
+ export { ObjectCardMainComponent };
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"object-card-main.component.js","sourceRoot":"ng://@senior-gestao-empresarial/angular-components/","sources":["components/object-card/elements/main/object-card-main.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ContentChild, EventEmitter, HostListener, Input, Output } from \"@angular/core\";\nimport { MenuItem } from \"primeng/api\";\nimport { Observable } from \"rxjs\";\n\nimport { ThumbnailSize } from \"../../../thumbnail/thumbnail-size\";\nimport { ThumbnailComponent } from \"../../../thumbnail/thumbnail.component\";\nimport { Breakpoints } from \"../../../utils\";\n\n@Component({\n    selector: \"erp-object-card-main\",\n    templateUrl: \"./object-card-main.component.html\",\n    styleUrls: [\"./object-card-main.component.scss\"],\n})\nexport class ObjectCardMainComponent implements AfterContentInit {\n    private static nextId = 0;\n\n    @Input()\n    public id = `erp-object-card-main-${ObjectCardMainComponent.getNextId()}`;\n\n    @Input()\n    public imageSource?: string;\n\n    @Input()\n    public imageFallback?: string;\n\n    @Input()\n    public imageAlt?: string;\n\n    @Input()\n    public iconClass = \"fa fa-picture-o\";\n\n    @Input()\n    public hasThumbnail = true;\n\n    @Input()\n    public hasDescription = true;\n\n    @Input()\n    public isBrand = false;\n\n    @Input()\n    public expandableImage = false;\n\n    @Input()\n    public imageLoader?: () => Observable<string> | Promise<string>;\n\n    @Input()\n    public label?: string;\n\n    @Input()\n    public description?: string;\n\n    @Input()\n    public buttonLabel?: string;\n\n    @Input()\n    public buttonModel?: MenuItem[];\n\n    @Output()\n    public buttonClick: EventEmitter<any> = new EventEmitter();\n\n    @ContentChild(ThumbnailComponent, { static: true })\n    public thumbnailComponent: ThumbnailComponent;\n\n    public showImageModal = false;\n    public fullImageSource?: string;\n    public loadingFullImage = false;\n\n    private _thumbnailSize = ThumbnailSize.Medium;\n\n    public set thumbnailSize(value: ThumbnailSize) {\n        this._thumbnailSize = value;\n        if (this.thumbnailComponent){\n            this.thumbnailComponent.size = value;\n        }\n    }\n\n    public get thumbnailSize() {\n        return this._thumbnailSize;\n    }\n\n    @HostListener(\"window:resize\")\n    public onResize() {\n        this.update();\n    }\n\n    public ngAfterContentInit() {\n        this.update();\n    }\n\n    public update() {\n        const windowWidth = window.innerWidth;\n\n        if (windowWidth <= Breakpoints.SM_MAX) {\n            this.thumbnailSize = ThumbnailSize.Small;\n        } else {\n            this.thumbnailSize = ThumbnailSize.Medium;\n        }\n    }\n\n    private static getNextId(): number {\n        const id = ObjectCardMainComponent.nextId;\n        ObjectCardMainComponent.nextId++;\n        return id;\n    }\n\n    public getImageAltText(): string {\n        const altText = this.imageAlt || this.label || '';\n        return altText.replace(/\\bimage\\b/gi, '').replace(/\\bimagem\\b/gi, '').trim();\n    }\n\n    public async openImageModal() {\n        if (!this.expandableImage || !this.imageSource) {\n            return;\n        }\n\n        this.showImageModal = true;\n        this.fullImageSource = await this.resolveFullImageSource();\n    }\n\n    private async resolveFullImageSource(): Promise<string> {\n        if (!this.imageLoader || this.fullImageSource) {\n            return this.fullImageSource || this.imageSource;\n        }\n\n        this.loadingFullImage = true;\n        try {\n            const result = this.imageLoader();\n            return await (result instanceof Promise ? result : result.toPromise());\n        } catch (error) {\n            console.error('Erro ao carregar imagem completa:', error);\n            return this.imageSource;\n        } finally {\n            this.loadingFullImage = false;\n        }\n    }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export * from "./object-card.module";
2
+ export * from "./object-card.component";
3
+ export * from "./elements/field/object-card-field.component";
4
+ export * from "./elements/main/object-card-main.component";
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL29iamVjdC1jYXJkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsNENBQTRDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9vYmplY3QtY2FyZC5tb2R1bGVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL29iamVjdC1jYXJkLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vZWxlbWVudHMvZmllbGQvb2JqZWN0LWNhcmQtZmllbGQuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9lbGVtZW50cy9tYWluL29iamVjdC1jYXJkLW1haW4uY29tcG9uZW50XCI7XG4iXX0=
@@ -0,0 +1,144 @@
1
+ import { __decorate } from "tslib";
2
+ import { animate, state, style, transition, trigger } from "@angular/animations";
3
+ import { Component, ContentChild, ContentChildren, EventEmitter, Input, Output, ViewChild } from "@angular/core";
4
+ import { EnumSeverity } from "../shared/models/enum-severity";
5
+ import { Breakpoints } from "../utils/breakpoints";
6
+ import { ObjectCardFieldComponent } from "./elements/field/object-card-field.component";
7
+ import { ObjectCardMainComponent } from "./elements/main/object-card-main.component";
8
+ var ObjectCardComponent = /** @class */ (function () {
9
+ function ObjectCardComponent() {
10
+ this.id = "erp-object-card-" + ObjectCardComponent_1.getNextId();
11
+ this.expanded = false;
12
+ this.expandTooltip = "Abrir painel";
13
+ this.collapseTooltip = "Fechar painel";
14
+ this.fieldsMinWidth = 200;
15
+ this.expandedChange = new EventEmitter();
16
+ this.maxVisibleFields = 0;
17
+ this.severity = EnumSeverity.Default;
18
+ this.EnumSeverity = EnumSeverity;
19
+ }
20
+ ObjectCardComponent_1 = ObjectCardComponent;
21
+ ObjectCardComponent.prototype.ngAfterContentChecked = function () {
22
+ this.update();
23
+ };
24
+ ObjectCardComponent.prototype.update = function () {
25
+ var windowWidth = window.innerWidth;
26
+ var containerWidth = this.container.nativeElement.getBoundingClientRect().width;
27
+ var mainFieldWidth = this.cardMainContainer.nativeElement.getBoundingClientRect().width;
28
+ var remainingSpace = containerWidth - mainFieldWidth;
29
+ var fieldsMinWidth = this.fieldsMinWidth;
30
+ var expandIconWidth = this.iconContainer.nativeElement.getBoundingClientRect().width;
31
+ var maxFieldQtd;
32
+ if (windowWidth <= Breakpoints.SM_MAX) {
33
+ maxFieldQtd = 0;
34
+ }
35
+ else {
36
+ maxFieldQtd = Math.floor((remainingSpace) / fieldsMinWidth);
37
+ }
38
+ var hasExpandIcon = maxFieldQtd && maxFieldQtd < this.fields.length;
39
+ if (hasExpandIcon) {
40
+ this.iconContainer.nativeElement.style.display = 'flex';
41
+ remainingSpace = remainingSpace - expandIconWidth;
42
+ maxFieldQtd = Math.floor((remainingSpace) / fieldsMinWidth);
43
+ }
44
+ else {
45
+ this.iconContainer.nativeElement.style.display = 'none';
46
+ }
47
+ this.maxVisibleFields = maxFieldQtd;
48
+ if (maxFieldQtd >= this.fields.length && this.expanded) {
49
+ this.collapse();
50
+ }
51
+ };
52
+ ObjectCardComponent.prototype.toggle = function () {
53
+ this.expanded ? this.collapse() : this.expand();
54
+ };
55
+ ObjectCardComponent.prototype.expand = function () {
56
+ this.expanded = true;
57
+ this.expandedChange.emit(this.expanded);
58
+ };
59
+ ObjectCardComponent.prototype.collapse = function () {
60
+ this.expanded = false;
61
+ this.expandedChange.emit(this.expanded);
62
+ };
63
+ ObjectCardComponent.getNextId = function () {
64
+ var id = ObjectCardComponent_1.nextId;
65
+ ObjectCardComponent_1.nextId++;
66
+ return id;
67
+ };
68
+ var ObjectCardComponent_1;
69
+ ObjectCardComponent.nextId = 0;
70
+ __decorate([
71
+ Input()
72
+ ], ObjectCardComponent.prototype, "id", void 0);
73
+ __decorate([
74
+ Input()
75
+ ], ObjectCardComponent.prototype, "expanded", void 0);
76
+ __decorate([
77
+ Input()
78
+ ], ObjectCardComponent.prototype, "expandTooltip", void 0);
79
+ __decorate([
80
+ Input()
81
+ ], ObjectCardComponent.prototype, "collapseTooltip", void 0);
82
+ __decorate([
83
+ Input()
84
+ ], ObjectCardComponent.prototype, "fieldsMinWidth", void 0);
85
+ __decorate([
86
+ Output()
87
+ ], ObjectCardComponent.prototype, "expandedChange", void 0);
88
+ __decorate([
89
+ ContentChild(ObjectCardMainComponent, { static: true })
90
+ ], ObjectCardComponent.prototype, "main", void 0);
91
+ __decorate([
92
+ ContentChildren(ObjectCardFieldComponent, { descendants: true })
93
+ ], ObjectCardComponent.prototype, "fields", void 0);
94
+ __decorate([
95
+ Input()
96
+ ], ObjectCardComponent.prototype, "severity", void 0);
97
+ __decorate([
98
+ Input()
99
+ ], ObjectCardComponent.prototype, "borderButtonOptions", void 0);
100
+ __decorate([
101
+ ViewChild('contentContainer', { static: true })
102
+ ], ObjectCardComponent.prototype, "container", void 0);
103
+ __decorate([
104
+ ViewChild('cardMainContainer', { static: true })
105
+ ], ObjectCardComponent.prototype, "cardMainContainer", void 0);
106
+ __decorate([
107
+ ViewChild('iconContainer', { static: true })
108
+ ], ObjectCardComponent.prototype, "iconContainer", void 0);
109
+ ObjectCardComponent = ObjectCardComponent_1 = __decorate([
110
+ Component({
111
+ selector: "erp-object-card",
112
+ template: "<div [id]=\"id\" class=\"container\">\n <s-border-button\n *ngIf=\"\n borderButtonOptions?.visible\n ? borderButtonOptions?.visible(severity)\n : false\n \"\n [severity]=\"severity\"\n [options]=\"borderButtonOptions\"\n class=\"object-card__border-button\"\n [@BorderButtonAnimation]\n ></s-border-button>\n\n <div\n [id]=\"id + '-main-container'\"\n class=\"main-container\"\n #contentContainer\n [ngClass]=\"{\n 'with-hidden-fields': fields.length > maxVisibleFields,\n 'with-visible-fields': fields.length && maxVisibleFields,\n 'main-container--severity-default': severity === EnumSeverity.Default,\n 'main-container--severity-info': severity === EnumSeverity.Info,\n 'main-container--severity-warn': severity === EnumSeverity.Warn,\n 'main-container--severity-error': severity === EnumSeverity.Error,\n 'main-container--severity-success': severity == EnumSeverity.Success\n }\"\n >\n <div class=\"object-content\">\n <div class=\"erp-object-card-main\" #cardMainContainer [style.min-width.px]=\"fieldsMinWidth\">\n <ng-content select=\"erp-object-card-main\"></ng-content>\n </div>\n\n <div class=\"divider\" *ngIf=\"maxVisibleFields && fields.length\"></div>\n\n <div *ngFor=\"let field of (fields.toArray() | slice: 0:maxVisibleFields)\"\n class=\"erp-object-card-field\"\n [style.min-width.px]=\"fieldsMinWidth\">\n\n <ng-container *ngTemplateOutlet=\"field.content\"></ng-container>\n </div>\n </div>\n\n <button\n #iconContainer\n [id]=\"id + '-expand-icon-container'\"\n class=\"expand-icon-container\"\n (click)=\"toggle()\"\n [pTooltip]=\"expanded ? collapseTooltip : expandTooltip\"\n [attr.aria-label]=\"expanded ? collapseTooltip : expandTooltip\"\n title=\"Expandir/Recolher\"\n tooltipPosition=\"top\"\n [showDelay]=\"500\"\n type=\"button\"\n >\n <span\n [id]=\"id + '-expand-icon'\"\n class=\"expand-icon fa\"\n [ngClass]=\"{ 'fa-minus': expanded, 'fa-plus': !expanded }\"\n ></span>\n </button>\n </div>\n\n <div\n [id]=\"id + '-expandable-container'\"\n [@expandableContent]=\"expanded\"\n class=\"expandable-container\"\n [ngClass]=\"{\n 'expandable-container--severity-default':\n severity === EnumSeverity.Default,\n 'expandable-container--severity-info': severity === EnumSeverity.Info,\n 'expandable-container--severity-warn': severity === EnumSeverity.Warn,\n 'expandable-container--severity-error': severity === EnumSeverity.Error,\n 'expandable-container--severity-success':\n severity == EnumSeverity.Success\n }\"\n >\n <div class=\"childlist\">\n <ng-container\n *ngFor=\"\n let field of fields.toArray()\n | slice : maxVisibleFields : fields.length\n \"\n >\n <div class=\"erp-object-card-field\" [style.min-width.px]=\"fieldsMinWidth\">\n <ng-container\n *ngTemplateOutlet=\"field.content\"\n ></ng-container>\n </div>\n </ng-container>\n </div>\n </div>\n</div>\n",
113
+ animations: [
114
+ trigger("expandableContent", [
115
+ state("*", style({
116
+ height: "0",
117
+ })),
118
+ state("false", style({
119
+ height: "0",
120
+ })),
121
+ state("true", style({
122
+ height: "*",
123
+ })),
124
+ transition("* => true", animate("200ms ease-out")),
125
+ transition("false <=> true", animate("200ms ease-out")),
126
+ ]),
127
+ trigger("BorderButtonAnimation", [
128
+ transition(":enter", [
129
+ style({ transform: "scaleY(0)", opacity: 0 }),
130
+ animate("300ms ease", style({ transform: "scaleY(1)", opacity: 1 })),
131
+ ]),
132
+ transition(":leave", [
133
+ style({ transform: "scaleY(1)", opacity: 1 }),
134
+ animate("300ms ease", style({ transform: "scaleY(0)", opacity: 0 })),
135
+ ]),
136
+ ]),
137
+ ],
138
+ styles: [":host{display:block}:host::ng-deep .sds-badge{height:auto;white-space:normal}.container{margin-bottom:20px;position:relative}.main-container{display:-ms-flexbox;display:flex}.expandable-container,.main-container{background-color:#fff;border:1px solid #ccc;position:relative;overflow:hidden;width:100%}.expandable-container--severity-default{border-color:#ccc;border-top:initial}.expandable-container--severity-info{transition:border-color .5s;border-color:#428bca;border-top:initial}.expandable-container--severity-warn{transition:border-color .5s;border-color:#f8931f;border-top:initial}.expandable-container--severity-error{transition:border-color .5s;border-color:#c13018;border-top:initial}.expandable-container--severity-success{transition:border-color .5s;border-color:#0c9348;border-top:initial}.main-container--severity-default{border-color:#ccc}.main-container--severity-info{transition:border-color .5s;border-color:#428bca}.main-container--severity-warn{transition:border-color .5s;border-color:#f8931f}.main-container--severity-error{transition:border-color .5s;border-color:#c13018}.main-container--severity-success{transition:border-color .5s;border-color:#0c9348}.object-card__border-button{position:absolute;top:-13px;right:15px;z-index:1}.expandable-container{border-top:none;box-shadow:inset 0 6px 4px -4px #ddd;margin-top:-1px}.expand-icon-container{display:none;text-align:center;-ms-flex-align:center;align-items:center;cursor:pointer;padding:12px;background:0 0;border:none;color:inherit}.expand-icon{-ms-flex:1;flex:1}.object-content{display:-ms-flexbox;display:flex;width:100%}.erp-object-card-main{overflow:hidden;padding:15px}.main-container.with-visible-fields .erp-object-card-main{max-width:30%}@media all and (-ms-high-contrast:none),(-ms-high-contrast:active){.main-container.with-visible-fields .erp-object-card-main{width:20%}}.erp-object-card-field{overflow:hidden;height:100%}.main-container .erp-object-card-field{padding:15px}.main-container .divider{width:1px;-ms-flex-negative:0;flex-shrink:0;background-color:#ccc;margin:15px -1px 15px 0}.main-container.with-hidden-fields .object-content{width:calc(100% - 35px)}.main-container.with-hidden-fields .expand-icon-container{display:-ms-flexbox;display:flex}::ng-deep .object-card-button{padding-left:0!important;padding-right:10px!important;border:none!important;height:auto!important;min-width:auto!important;text-align:left!important}@media (max-width:767px){.erp-object-card-main{max-width:calc(100% - 50px)}}.childlist{width:100%;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding:1em;gap:1em}"]
139
+ })
140
+ ], ObjectCardComponent);
141
+ return ObjectCardComponent;
142
+ }());
143
+ export { ObjectCardComponent };
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"object-card.component.js","sourceRoot":"ng://@senior-gestao-empresarial/angular-components/","sources":["components/object-card/object-card.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from \"@angular/animations\";\nimport {\n    AfterContentChecked,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    QueryList,\n    ViewChild\n} from \"@angular/core\";\n\nimport { BorderButtonOptions } from \"../shared/models/border-button-options\";\nimport { EnumSeverity } from \"../shared/models/enum-severity\";\nimport { Breakpoints } from \"../utils/breakpoints\";\nimport { ObjectCardFieldComponent } from \"./elements/field/object-card-field.component\";\nimport { ObjectCardMainComponent } from \"./elements/main/object-card-main.component\";\n\n@Component({\n    selector: \"erp-object-card\",\n    templateUrl: \"./object-card.component.html\",\n    styleUrls: [\"./object-card.component.scss\"],\n    animations: [\n        trigger(\"expandableContent\", [\n            state(\n                \"*\",\n                style({\n                    height: \"0\",\n                })\n            ),\n            state(\n                \"false\",\n                style({\n                    height: \"0\",\n                })\n            ),\n            state(\n                \"true\",\n                style({\n                    height: \"*\",\n                })\n            ),\n            transition(\"* => true\", animate(\"200ms ease-out\")),\n            transition(\"false <=> true\", animate(\"200ms ease-out\")),\n        ]),\n        trigger(\"BorderButtonAnimation\", [\n            transition(\":enter\", [\n                style({ transform: \"scaleY(0)\", opacity: 0 }),\n                animate(\"300ms ease\", style({ transform: \"scaleY(1)\", opacity: 1 })),\n            ]),\n            transition(\":leave\", [\n                style({ transform: \"scaleY(1)\", opacity: 1 }),\n                animate(\"300ms ease\", style({ transform: \"scaleY(0)\", opacity: 0 })),\n            ]),\n        ]),\n    ],\n})\nexport class ObjectCardComponent implements AfterContentChecked {\n    private static nextId = 0;\n\n    @Input()\n    public id = `erp-object-card-${ObjectCardComponent.getNextId()}`;\n\n    @Input()\n    public expanded = false;\n\n    @Input()\n    public expandTooltip = \"Abrir painel\";\n\n    @Input()\n    public collapseTooltip = \"Fechar painel\";\n\n    @Input()\n    public fieldsMinWidth = 200;\n\n    @Output()\n    public expandedChange = new EventEmitter<boolean>();\n\n    @ContentChild(ObjectCardMainComponent, { static: true })\n    public main: ObjectCardMainComponent;\n\n    @ContentChildren(ObjectCardFieldComponent, { descendants: true })\n    public fields?: QueryList<ObjectCardFieldComponent>;\n\n    public maxVisibleFields = 0;\n\n    @Input()\n    severity = EnumSeverity.Default;\n\n    @Input()\n    borderButtonOptions: BorderButtonOptions;\n\n    readonly EnumSeverity = EnumSeverity;\n\n    @ViewChild('contentContainer', { static: true })\n    private readonly container: ElementRef<HTMLElement>;\n\n    @ViewChild('cardMainContainer', { static: true })\n    private readonly cardMainContainer: ElementRef<HTMLElement>\n\n    @ViewChild('iconContainer', { static: true })\n    private readonly iconContainer: ElementRef<HTMLElement>\n\n    public ngAfterContentChecked(): void {\n        this.update();\n    }\n\n    private update() {\n        const windowWidth = window.innerWidth;\n        const containerWidth = this.container.nativeElement.getBoundingClientRect().width;\n        const mainFieldWidth = this.cardMainContainer.nativeElement.getBoundingClientRect().width;\n        let remainingSpace =  containerWidth - mainFieldWidth;\n        const fieldsMinWidth = this.fieldsMinWidth;\n        const expandIconWidth = this.iconContainer.nativeElement.getBoundingClientRect().width;\n\n        let maxFieldQtd: number;\n\n        if (windowWidth <= Breakpoints.SM_MAX) {\n            maxFieldQtd = 0\n        } else {\n            maxFieldQtd = Math.floor((remainingSpace) / fieldsMinWidth);\n        }\n\n        const hasExpandIcon = maxFieldQtd && maxFieldQtd < this.fields.length\n\n        if (hasExpandIcon) {\n            this.iconContainer.nativeElement.style.display = 'flex';\n            remainingSpace = remainingSpace - expandIconWidth;\n            maxFieldQtd = Math.floor((remainingSpace) / fieldsMinWidth);\n        }else {\n            this.iconContainer.nativeElement.style.display = 'none';\n        }\n\n        this.maxVisibleFields = maxFieldQtd;\n\n        if (maxFieldQtd >= this.fields.length && this.expanded) {\n            this.collapse();\n        }\n    }\n\n    public toggle() {\n        this.expanded ? this.collapse() : this.expand();\n    }\n\n    public expand() {\n        this.expanded = true;\n        this.expandedChange.emit(this.expanded);\n    }\n\n    public collapse() {\n        this.expanded = false;\n        this.expandedChange.emit(this.expanded);\n    }\n\n    private static getNextId(): number {\n        const id = ObjectCardComponent.nextId;\n        ObjectCardComponent.nextId++;\n        return id;\n    }\n\n}\n"]}
@@ -0,0 +1,25 @@
1
+ import { __decorate } from "tslib";
2
+ import { CommonModule } from "@angular/common";
3
+ import { NgModule } from "@angular/core";
4
+ import { TooltipModule } from "primeng/tooltip";
5
+ import { DialogModule } from "primeng/dialog";
6
+ import { ButtonModule, LoadingStateModule } from "@seniorsistemas/angular-components";
7
+ import { ThumbnailModule } from "../thumbnail/thumbnail.module";
8
+ import { ObjectCardComponent } from "./object-card.component";
9
+ import { ObjectCardMainComponent } from "./elements/main/object-card-main.component";
10
+ import { ObjectCardFieldComponent } from "./elements/field/object-card-field.component";
11
+ import { BorderButtonModule } from "../shared/border-button/border-button.module";
12
+ var ErpObjectCardModule = /** @class */ (function () {
13
+ function ErpObjectCardModule() {
14
+ }
15
+ ErpObjectCardModule = __decorate([
16
+ NgModule({
17
+ imports: [CommonModule, TooltipModule, DialogModule, ThumbnailModule, ButtonModule, LoadingStateModule, BorderButtonModule],
18
+ declarations: [ObjectCardComponent, ObjectCardMainComponent, ObjectCardFieldComponent],
19
+ exports: [ThumbnailModule, ObjectCardComponent, ObjectCardMainComponent, ObjectCardFieldComponent],
20
+ })
21
+ ], ErpObjectCardModule);
22
+ return ErpObjectCardModule;
23
+ }());
24
+ export { ErpObjectCardModule };
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWNhcmQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvci1nZXN0YW8tZW1wcmVzYXJpYWwvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9vYmplY3QtY2FyZC9vYmplY3QtY2FyZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNoRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUMsT0FBTyxFQUFFLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRXRGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNyRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUN4RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQU9sRjtJQUFBO0lBQWtDLENBQUM7SUFBdEIsbUJBQW1CO1FBTC9CLFFBQVEsQ0FBQztZQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLGVBQWUsRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLENBQUM7WUFDM0gsWUFBWSxFQUFFLENBQUMsbUJBQW1CLEVBQUUsdUJBQXVCLEVBQUUsd0JBQXdCLENBQUM7WUFDdEYsT0FBTyxFQUFFLENBQUMsZUFBZSxFQUFFLG1CQUFtQixFQUFFLHVCQUF1QixFQUFFLHdCQUF3QixDQUFDO1NBQ3JHLENBQUM7T0FDVyxtQkFBbUIsQ0FBRztJQUFELDBCQUFDO0NBQUEsQUFBbkMsSUFBbUM7U0FBdEIsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgVG9vbHRpcE1vZHVsZSB9IGZyb20gXCJwcmltZW5nL3Rvb2x0aXBcIjtcbmltcG9ydCB7IERpYWxvZ01vZHVsZSB9IGZyb20gXCJwcmltZW5nL2RpYWxvZ1wiO1xuaW1wb3J0IHsgQnV0dG9uTW9kdWxlLCBMb2FkaW5nU3RhdGVNb2R1bGUgfSBmcm9tIFwiQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50c1wiO1xuXG5pbXBvcnQgeyBUaHVtYm5haWxNb2R1bGUgfSBmcm9tIFwiLi4vdGh1bWJuYWlsL3RodW1ibmFpbC5tb2R1bGVcIjtcbmltcG9ydCB7IE9iamVjdENhcmRDb21wb25lbnQgfSBmcm9tIFwiLi9vYmplY3QtY2FyZC5jb21wb25lbnRcIjtcbmltcG9ydCB7IE9iamVjdENhcmRNYWluQ29tcG9uZW50IH0gZnJvbSBcIi4vZWxlbWVudHMvbWFpbi9vYmplY3QtY2FyZC1tYWluLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgT2JqZWN0Q2FyZEZpZWxkQ29tcG9uZW50IH0gZnJvbSBcIi4vZWxlbWVudHMvZmllbGQvb2JqZWN0LWNhcmQtZmllbGQuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBCb3JkZXJCdXR0b25Nb2R1bGUgfSBmcm9tIFwiLi4vc2hhcmVkL2JvcmRlci1idXR0b24vYm9yZGVyLWJ1dHRvbi5tb2R1bGVcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBUb29sdGlwTW9kdWxlLCBEaWFsb2dNb2R1bGUsIFRodW1ibmFpbE1vZHVsZSwgQnV0dG9uTW9kdWxlLCBMb2FkaW5nU3RhdGVNb2R1bGUsIEJvcmRlckJ1dHRvbk1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbT2JqZWN0Q2FyZENvbXBvbmVudCwgT2JqZWN0Q2FyZE1haW5Db21wb25lbnQsIE9iamVjdENhcmRGaWVsZENvbXBvbmVudF0sXG4gICAgZXhwb3J0czogW1RodW1ibmFpbE1vZHVsZSwgT2JqZWN0Q2FyZENvbXBvbmVudCwgT2JqZWN0Q2FyZE1haW5Db21wb25lbnQsIE9iamVjdENhcmRGaWVsZENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEVycE9iamVjdENhcmRNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,25 @@
1
+ import { __decorate } from "tslib";
2
+ import { Component, Input } from "@angular/core";
3
+ import { EnumSeverity } from "../models/enum-severity";
4
+ var BorderButtonComponent = /** @class */ (function () {
5
+ function BorderButtonComponent() {
6
+ this.severity = EnumSeverity.Default;
7
+ this.EnumSeverity = EnumSeverity;
8
+ }
9
+ __decorate([
10
+ Input()
11
+ ], BorderButtonComponent.prototype, "severity", void 0);
12
+ __decorate([
13
+ Input()
14
+ ], BorderButtonComponent.prototype, "options", void 0);
15
+ BorderButtonComponent = __decorate([
16
+ Component({
17
+ selector: "s-border-button",
18
+ template: "<button\n class=\"border-button\"\n [ngClass]=\"{\n 'border-button--severity-default': severity === EnumSeverity.Default,\n 'border-button--severity-info': severity === EnumSeverity.Info,\n 'border-button--severity-warn': severity === EnumSeverity.Warn,\n 'border-button--severity-error': severity === EnumSeverity.Error,\n 'border-button--severity-success': severity == EnumSeverity.Success,\n 'border-button--disabled': options?.disabled\n ? options?.disabled(severity)\n : false\n }\"\n (click)=\"options?.onClick ? options?.onClick(severity) : null\"\n [pTooltip]=\"options?.tooltip ? options?.tooltip(severity) : null\"\n tooltipPosition=\"left\"\n [disabled]=\"options?.disabled ? options?.disabled(severity) : false\"\n>\n <span class=\"border-button__label\">\n {{ options?.label ? options?.label(severity) : null }}\n </span>\n <span\n *ngIf=\"options?.icon ? options?.icon(severity) : false\"\n class=\"border-button__icon {{ options?.icon(severity) }}\"\n ></span>\n</button>\n",
19
+ styles: [".border-button{padding:0 8px;border:1px solid;border-radius:12px;height:23px;max-width:320px;display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;-ms-flex-align:center;align-items:center;cursor:pointer}.border-button__label{font-family:Open Sans,sans-serif;font-size:12px;line-height:150%;width:100%;display:block;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.border-button__icon{font-size:12px;color:#333;margin-left:8px}.border-button--severity-default{border-color:#ccc;background-color:#fff}.border-button--severity-info{border-color:#428bca;background-color:#d5e8ec;transition:background-color .5s,border-color .5s}.border-button--severity-info:enabled:hover{background-color:#9ecad4;cursor:pointer}.border-button--severity-info:enabled:active{transition:none;background-color:#67acbc;border-color:#67acbc}.border-button--severity-warn{border-color:#f8931f;background-color:#fce3ba;transition:background-color .5s,border-color .5s}.border-button--severity-warn:enabled:hover{background-color:#f8bf5e;cursor:pointer}.border-button--severity-warn:enabled:active{transition:none;background-color:#f5a319;border-color:#f5a319}.border-button--severity-error{border-color:#c13018;background-color:#fcd2d2;transition:background-color .5s,border-color .5s}.border-button--severity-error:enabled:hover{background-color:#f89696;cursor:pointer}.border-button--severity-error:enabled:active{transition:none;background-color:#f45b5b;border-color:#f45b5b}.border-button--severity-success{border-color:#0c9348;background-color:#e6ffb3;transition:background-color .5s,border-color .5s}.border-button--severity-success:enabled:hover{background-color:#c8ff5c;cursor:pointer}.border-button--severity-success:enabled:active{transition:none;background-color:#ade500;border-color:#ade500}.border-button--disabled:disabled:hover{cursor:default}"]
20
+ })
21
+ ], BorderButtonComponent);
22
+ return BorderButtonComponent;
23
+ }());
24
+ export { BorderButtonComponent };
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9yZGVyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3NoYXJlZC9ib3JkZXItYnV0dG9uL2JvcmRlci1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFPdkQ7SUFBQTtRQUVJLGFBQVEsR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDO1FBS3ZCLGlCQUFZLEdBQUcsWUFBWSxDQUFDO0lBQ3pDLENBQUM7SUFORztRQURDLEtBQUssRUFBRTsyREFDd0I7SUFHaEM7UUFEQyxLQUFLLEVBQUU7MERBQ3FCO0lBTHBCLHFCQUFxQjtRQUxqQyxTQUFTLENBQUM7WUFDUCxRQUFRLEVBQUUsaUJBQWlCO1lBQzNCLDhsQ0FBNkM7O1NBRWhELENBQUM7T0FDVyxxQkFBcUIsQ0FRakM7SUFBRCw0QkFBQztDQUFBLEFBUkQsSUFRQztTQVJZLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQm9yZGVyQnV0dG9uT3B0aW9ucyB9IGZyb20gXCIuLi9tb2RlbHMvYm9yZGVyLWJ1dHRvbi1vcHRpb25zXCI7XG5pbXBvcnQgeyBFbnVtU2V2ZXJpdHkgfSBmcm9tIFwiLi4vbW9kZWxzL2VudW0tc2V2ZXJpdHlcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy1ib3JkZXItYnV0dG9uXCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9ib3JkZXItYnV0dG9uLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL2JvcmRlci1idXR0b24uY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIEJvcmRlckJ1dHRvbkNvbXBvbmVudCB7XG4gICAgQElucHV0KClcbiAgICBzZXZlcml0eSA9IEVudW1TZXZlcml0eS5EZWZhdWx0O1xuXG4gICAgQElucHV0KClcbiAgICBvcHRpb25zOiBCb3JkZXJCdXR0b25PcHRpb25zO1xuXG4gICAgcmVhZG9ubHkgRW51bVNldmVyaXR5ID0gRW51bVNldmVyaXR5O1xufVxuIl19
@@ -0,0 +1,19 @@
1
+ import { __decorate } from "tslib";
2
+ import { CommonModule } from "@angular/common";
3
+ import { NgModule } from "@angular/core";
4
+ import { TooltipModule } from "primeng/tooltip";
5
+ import { BorderButtonComponent } from "./border-button.component";
6
+ var BorderButtonModule = /** @class */ (function () {
7
+ function BorderButtonModule() {
8
+ }
9
+ BorderButtonModule = __decorate([
10
+ NgModule({
11
+ imports: [CommonModule, TooltipModule],
12
+ declarations: [BorderButtonComponent],
13
+ exports: [BorderButtonComponent]
14
+ })
15
+ ], BorderButtonModule);
16
+ return BorderButtonModule;
17
+ }());
18
+ export { BorderButtonModule };
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9yZGVyLWJ1dHRvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3NoYXJlZC9ib3JkZXItYnV0dG9uL2JvcmRlci1idXR0b24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFaEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFPbEU7SUFBQTtJQUFpQyxDQUFDO0lBQXJCLGtCQUFrQjtRQUw5QixRQUFRLENBQUM7WUFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsYUFBYSxDQUFDO1lBQ3RDLFlBQVksRUFBRSxDQUFDLHFCQUFxQixDQUFDO1lBQ3JDLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO1NBQ25DLENBQUM7T0FDVyxrQkFBa0IsQ0FBRztJQUFELHlCQUFDO0NBQUEsQUFBbEMsSUFBa0M7U0FBckIsa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgVG9vbHRpcE1vZHVsZSB9IGZyb20gXCJwcmltZW5nL3Rvb2x0aXBcIjtcblxuaW1wb3J0IHsgQm9yZGVyQnV0dG9uQ29tcG9uZW50IH0gZnJvbSBcIi4vYm9yZGVyLWJ1dHRvbi5jb21wb25lbnRcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBUb29sdGlwTW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtCb3JkZXJCdXR0b25Db21wb25lbnRdLFxuICAgIGV4cG9ydHM6IFtCb3JkZXJCdXR0b25Db21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIEJvcmRlckJ1dHRvbk1vZHVsZSB7fVxuIl19
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9yZGVyLWJ1dHRvbi1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvci1nZXN0YW8tZW1wcmVzYXJpYWwvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9zaGFyZWQvbW9kZWxzL2JvcmRlci1idXR0b24tb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRW51bVNldmVyaXR5IH0gZnJvbSBcIi4vZW51bS1zZXZlcml0eVwiO1xuXG5leHBvcnQgdHlwZSBCb3JkZXJCdXR0b25PcHRpb25zID0ge1xuICAgIGxhYmVsOiAoc2V2ZXJpdHk6IEVudW1TZXZlcml0eSkgPT4gc3RyaW5nO1xuICAgIG9uQ2xpY2s/OiAoc2V2ZXJpdHk6IEVudW1TZXZlcml0eSkgPT4gdm9pZDtcbiAgICB2aXNpYmxlPzogKHNldmVyaXR5OiBFbnVtU2V2ZXJpdHkpID0+IGJvb2xlYW47XG4gICAgZGlzYWJsZWQ/OiAoc2V2ZXJpdHk6IEVudW1TZXZlcml0eSkgPT4gYm9vbGVhbjtcbiAgICB0b29sdGlwPzogKHNldmVyaXR5OiBFbnVtU2V2ZXJpdHkpID0+IHN0cmluZztcbiAgICBpY29uPzogKHNldmVyaXR5OiBFbnVtU2V2ZXJpdHkpID0+IHN0cmluZztcbn07XG4iXX0=
@@ -0,0 +1,9 @@
1
+ export var EnumSeverity;
2
+ (function (EnumSeverity) {
3
+ EnumSeverity["Default"] = "Default";
4
+ EnumSeverity["Info"] = "Info";
5
+ EnumSeverity["Warn"] = "Warn";
6
+ EnumSeverity["Error"] = "Error";
7
+ EnumSeverity["Success"] = "Success";
8
+ })(EnumSeverity || (EnumSeverity = {}));
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS1zZXZlcml0eS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3ItZ2VzdGFvLWVtcHJlc2FyaWFsL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvc2hhcmVkL21vZGVscy9lbnVtLXNldmVyaXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLFlBTVg7QUFORCxXQUFZLFlBQVk7SUFDcEIsbUNBQW1CLENBQUE7SUFDbkIsNkJBQWEsQ0FBQTtJQUNiLDZCQUFhLENBQUE7SUFDYiwrQkFBZSxDQUFBO0lBQ2YsbUNBQW1CLENBQUE7QUFDdkIsQ0FBQyxFQU5XLFlBQVksS0FBWixZQUFZLFFBTXZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gRW51bVNldmVyaXR5IHtcbiAgICBEZWZhdWx0ID0gXCJEZWZhdWx0XCIsXG4gICAgSW5mbyA9IFwiSW5mb1wiLFxuICAgIFdhcm4gPSBcIldhcm5cIixcbiAgICBFcnJvciA9IFwiRXJyb3JcIixcbiAgICBTdWNjZXNzID0gXCJTdWNjZXNzXCIsXG59XG4iXX0=
@@ -0,0 +1,4 @@
1
+ export * from "./thumbnail.module";
2
+ export * from "./thumbnail.component";
3
+ export * from "./thumbnail-size";
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3RodW1ibmFpbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL3RodW1ibmFpbC5tb2R1bGVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3RodW1ibmFpbC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3RodW1ibmFpbC1zaXplXCI7XG4iXX0=
@@ -0,0 +1,7 @@
1
+ export var ThumbnailSize;
2
+ (function (ThumbnailSize) {
3
+ ThumbnailSize["Small"] = "small";
4
+ ThumbnailSize["Medium"] = "medium";
5
+ ThumbnailSize["Large"] = "large";
6
+ })(ThumbnailSize || (ThumbnailSize = {}));
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlsLXNpemUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3RodW1ibmFpbC90aHVtYm5haWwtc2l6ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxhQUlYO0FBSkQsV0FBWSxhQUFhO0lBQ3JCLGdDQUFlLENBQUE7SUFDZixrQ0FBaUIsQ0FBQTtJQUNqQixnQ0FBZSxDQUFBO0FBQ25CLENBQUMsRUFKVyxhQUFhLEtBQWIsYUFBYSxRQUl4QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFRodW1ibmFpbFNpemUge1xuICAgIFNtYWxsID0gXCJzbWFsbFwiLFxuICAgIE1lZGl1bSA9IFwibWVkaXVtXCIsXG4gICAgTGFyZ2UgPSBcImxhcmdlXCIsXG59XG4iXX0=
@@ -0,0 +1,99 @@
1
+ import { __decorate } from "tslib";
2
+ import { Component, Input, ViewChild, } from "@angular/core";
3
+ import { from, Subject } from "rxjs";
4
+ import { takeUntil } from "rxjs/operators";
5
+ import { ThumbnailSize } from "./thumbnail-size";
6
+ import { ThumbnailService } from "./thumbnail.service";
7
+ var ThumbnailComponent = /** @class */ (function () {
8
+ function ThumbnailComponent(thumbnailService) {
9
+ this.thumbnailService = thumbnailService;
10
+ this.fallback = false;
11
+ this.id = "s-thumbnail-" + ThumbnailComponent_1.getNextId();
12
+ this.size = ThumbnailSize.Medium;
13
+ this.iconClass = "far fa-image";
14
+ this.hasAction = false;
15
+ this.actionIconClass = "fas fa-camera";
16
+ this.isTile = false;
17
+ this.isBrand = false;
18
+ this.ngUnsubscribe = new Subject();
19
+ }
20
+ ThumbnailComponent_1 = ThumbnailComponent;
21
+ ThumbnailComponent.prototype.ngOnDestroy = function () {
22
+ this.ngUnsubscribe.next();
23
+ this.ngUnsubscribe.complete();
24
+ };
25
+ ThumbnailComponent.prototype.ngAfterViewInit = function () {
26
+ var _this = this;
27
+ if (this.imgEl) {
28
+ this.imgEl.nativeElement.addEventListener("load", function () {
29
+ from(_this.thumbnailService.getBinaryFile(_this.imgEl.nativeElement))
30
+ .pipe(takeUntil(_this.ngUnsubscribe))
31
+ .subscribe(function (orientation) { return (_this.orientation = orientation); });
32
+ });
33
+ }
34
+ };
35
+ ThumbnailComponent.getNextId = function () {
36
+ var id = ThumbnailComponent_1.nextId;
37
+ ThumbnailComponent_1.nextId++;
38
+ return id;
39
+ };
40
+ ThumbnailComponent.prototype.getImageAltText = function () {
41
+ var altText = this.imageAlt || '';
42
+ // Remove a palavra "image" ou "imagem" para evitar redundância
43
+ return altText.replace(/\bimage\b/gi, '').replace(/\bimagem\b/gi, '').trim();
44
+ };
45
+ ThumbnailComponent.prototype.onImageError = function () {
46
+ this.fallback = true;
47
+ };
48
+ ThumbnailComponent.prototype.onFallbackError = function () {
49
+ this.imageFallback = null;
50
+ };
51
+ var ThumbnailComponent_1;
52
+ ThumbnailComponent.nextId = 0;
53
+ ThumbnailComponent.ctorParameters = function () { return [
54
+ { type: ThumbnailService }
55
+ ]; };
56
+ __decorate([
57
+ ViewChild("img", { static: false })
58
+ ], ThumbnailComponent.prototype, "imgEl", void 0);
59
+ __decorate([
60
+ Input()
61
+ ], ThumbnailComponent.prototype, "id", void 0);
62
+ __decorate([
63
+ Input()
64
+ ], ThumbnailComponent.prototype, "size", void 0);
65
+ __decorate([
66
+ Input()
67
+ ], ThumbnailComponent.prototype, "imageSource", void 0);
68
+ __decorate([
69
+ Input()
70
+ ], ThumbnailComponent.prototype, "imageFallback", void 0);
71
+ __decorate([
72
+ Input()
73
+ ], ThumbnailComponent.prototype, "imageAlt", void 0);
74
+ __decorate([
75
+ Input()
76
+ ], ThumbnailComponent.prototype, "iconClass", void 0);
77
+ __decorate([
78
+ Input()
79
+ ], ThumbnailComponent.prototype, "hasAction", void 0);
80
+ __decorate([
81
+ Input()
82
+ ], ThumbnailComponent.prototype, "actionIconClass", void 0);
83
+ __decorate([
84
+ Input()
85
+ ], ThumbnailComponent.prototype, "isTile", void 0);
86
+ __decorate([
87
+ Input()
88
+ ], ThumbnailComponent.prototype, "isBrand", void 0);
89
+ ThumbnailComponent = ThumbnailComponent_1 = __decorate([
90
+ Component({
91
+ selector: "s-thumbnail",
92
+ template: "<div\n [id]=\"id\"\n class=\"thumbnail-container thumbnail-container--{{size}}\"\n [attr.title]=\"imageAlt || 'Thumbnail'\"\n [ngClass]=\"{\n 'thumbnail-container--with-action': hasAction,\n 'thumbnail-container--brand': isBrand\n }\">\n <div\n [id]=\"id + '-image-container'\"\n *ngIf=\"imageSource || imageFallback\"\n class=\"image-container\"\n [ngClass]=\"{\n 'image-container--rounded': !isBrand\n }\">\n <ng-container *ngIf=\"!fallback; else fallbackImage\">\n <ng-container *ngTemplateOutlet=\"imageTemplate; context: {\n imgId: id + '-image',\n imgSrc: imageSource,\n errorHandler: onImageError,\n titleText: imageAlt || 'Thumbnail'\n }\"></ng-container>\n </ng-container>\n\n <ng-template #fallbackImage>\n <ng-container *ngIf=\"imageFallback; else iconFallback\">\n <ng-container *ngTemplateOutlet=\"imageTemplate; context: {\n imgId: id + '-image-fallback',\n imgSrc: imageFallback,\n errorHandler: onFallbackError,\n titleText: imageAlt || 'Thumbnail fallback'\n }\"></ng-container>\n </ng-container>\n </ng-template>\n\n <ng-template #iconFallback>\n <i\n ngClass=\"far fa-image\"\n class=\"fallback-img-color\">\n </i>\n </ng-template>\n\n <ng-template\n #imageTemplate\n let-imgId=\"imgId\"\n let-imgSrc=\"imgSrc\"\n let-errorHandler=\"errorHandler\"\n let-titleText=\"titleText\">\n <img\n #img\n [id]=\"imgId\"\n (error)=\"errorHandler()\"\n [src]=\"imgSrc\"\n alt=\"\"\n [attr.alt]=\"getImageAltText()\"\n [attr.title]=\"titleText\"\n width=\"100%\"\n height=\"auto\"\n [ngClass]=\"{\n 'smallThumbnail': isTile,\n 'exif-orientation-2': orientation == 2,\n 'exif-orientation-3': orientation == 3,\n 'exif-orientation-4': orientation == 4,\n 'exif-orientation-5': orientation == 5,\n 'exif-orientation-6': orientation == 6,\n 'exif-orientation-7': orientation == 7,\n 'exif-orientation-8': orientation == 8\n }\"/>\n </ng-template>\n </div>\n <div\n [id]=\"id + '-action-icon-container'\"\n *ngIf=\"hasAction\"\n class=\"action-icon-container action-icon-container--{{size}}\">\n <span\n [id]=\"id + '-action-icon'\"\n [class]=\"actionIconClass\"\n aria-hidden=\"true\">\n </span>\n </div>\n <div\n [id]=\"id + '-icon-container'\"\n *ngIf=\"!imageSource && !imageFallback\"\n class=\"icon-container icon-container--{{size}}\"\n [ngClass]=\"{'image-container--rounded': !isBrand}\">\n <span\n [id]=\"id + '-icon'\"\n [class]=\"iconClass\"\n aria-hidden=\"true\">\n </span>\n </div>\n\n <ng-content></ng-content>\n</div>\n",
93
+ styles: [":host{display:inline-block}.thumbnail-container{color:#fff;position:relative;text-align:center}.thumbnail-container--large{font-size:50px;height:100px;width:100px}.thumbnail-container--large.thumbnail-container--brand{width:200px}.thumbnail-container--medium{font-size:40px;height:70px;width:70px}.thumbnail-container--medium.thumbnail-container--brand{width:140px}.thumbnail-container--small{font-size:22px;height:40px;width:40px}.thumbnail-container--small.thumbnail-container--brand{width:80px}.thumbnail-container--with-action{cursor:pointer}.action-icon-container{background-color:#428bca;border-radius:50%;bottom:0;position:absolute;right:0}.action-icon-container--large,.action-icon-container--medium{font-size:10pt;height:25px;padding:3px;width:25px}.action-icon-container--small{font-size:6pt;height:16px;padding:2px;width:16px}.icon-container,.image-container{-ms-flex-align:center;align-items:center;height:100%;overflow:hidden;width:100%}.icon-container--rounded,.image-container--rounded{border-radius:50%}.smallThumbnail{height:40px!important}.icon-container{background-color:#ccc;color:#fff}.icon-container--large{line-height:98px}.icon-container--medium{line-height:68px}.icon-container--small{line-height:38px}.image-container{-ms-flex-align:center;align-items:center;background-color:#ccc;display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.image-container img{width:100%}.image-container img.exif-orientation-2{transform:rotateY(180deg)}.image-container img.exif-orientation-3{transform:rotate(180deg)}.image-container img.exif-orientation-4{transform:rotate(180deg) rotateY(180deg)}.image-container img.exif-orientation-5{transform:rotate(270deg) rotateY(180deg)}.image-container img.exif-orientation-6{transform:rotate(90deg)}.image-container img.exif-orientation-7{transform:rotate(90deg) rotateY(180deg)}.image-container img.exif-orientation-8{transform:rotate(270deg)}.fallback-img-color{color:#fff}"]
94
+ })
95
+ ], ThumbnailComponent);
96
+ return ThumbnailComponent;
97
+ }());
98
+ export { ThumbnailComponent };
99
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3ItZ2VzdGFvLWVtcHJlc2FyaWFsL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvdGh1bWJuYWlsL3RodW1ibmFpbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFFSCxTQUFTLEVBRVQsS0FBSyxFQUNMLFNBQVMsR0FFWixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNyQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFM0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBT3ZEO0lBd0NJLDRCQUE2QixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQXRDeEQsYUFBUSxHQUFHLEtBQUssQ0FBQztRQU9qQixPQUFFLEdBQUcsaUJBQWUsb0JBQWtCLENBQUMsU0FBUyxFQUFJLENBQUM7UUFHckQsU0FBSSxHQUFrQixhQUFhLENBQUMsTUFBTSxDQUFDO1FBWTNDLGNBQVMsR0FBRyxjQUFjLENBQUM7UUFHM0IsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUdsQixvQkFBZSxHQUFHLGVBQWUsQ0FBQztRQUdsQyxXQUFNLEdBQUcsS0FBSyxDQUFDO1FBR2YsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUVOLGtCQUFhLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUVvQixDQUFDOzJCQXhDM0Qsa0JBQWtCO0lBMENwQix3Q0FBVyxHQUFsQjtRQUNJLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDMUIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNsQyxDQUFDO0lBRU0sNENBQWUsR0FBdEI7UUFBQSxpQkFRQztRQVBHLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRTtnQkFDOUMsSUFBSSxDQUFDLEtBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsS0FBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQztxQkFDOUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7cUJBQ25DLFNBQVMsQ0FBQyxVQUFDLFdBQW1CLElBQUssT0FBQSxDQUFDLEtBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDLEVBQWhDLENBQWdDLENBQUMsQ0FBQztZQUM5RSxDQUFDLENBQUMsQ0FBQztTQUNOO0lBQ0wsQ0FBQztJQUdjLDRCQUFTLEdBQXhCO1FBQ0ksSUFBTSxFQUFFLEdBQUcsb0JBQWtCLENBQUMsTUFBTSxDQUFDO1FBQ3JDLG9CQUFrQixDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzVCLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVNLDRDQUFlLEdBQXRCO1FBQ0ksSUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsSUFBSSxFQUFFLENBQUM7UUFDcEMsK0RBQStEO1FBQy9ELE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLGNBQWMsRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNqRixDQUFDO0lBRU0seUNBQVksR0FBbkI7UUFDSSxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztJQUN6QixDQUFDO0lBRU0sNENBQWUsR0FBdEI7UUFDSSxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQztJQUM5QixDQUFDOztJQTNFYyx5QkFBTSxHQUFHLENBQUMsQ0FBQzs7Z0JBdUNxQixnQkFBZ0I7O0lBbEMvRDtRQURDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUM7cURBQ1g7SUFHekI7UUFEQyxLQUFLLEVBQUU7a0RBQ29EO0lBRzVEO1FBREMsS0FBSyxFQUFFO29EQUMwQztJQUdsRDtRQURDLEtBQUssRUFBRTsyREFDbUI7SUFHM0I7UUFEQyxLQUFLLEVBQUU7NkRBQ3NCO0lBRzlCO1FBREMsS0FBSyxFQUFFO3dEQUNnQjtJQUd4QjtRQURDLEtBQUssRUFBRTt5REFDMEI7SUFHbEM7UUFEQyxLQUFLLEVBQUU7eURBQ2lCO0lBR3pCO1FBREMsS0FBSyxFQUFFOytEQUNpQztJQUd6QztRQURDLEtBQUssRUFBRTtzREFDYztJQUd0QjtRQURDLEtBQUssRUFBRTt1REFDZTtJQXBDZCxrQkFBa0I7UUFMOUIsU0FBUyxDQUFDO1lBQ1AsUUFBUSxFQUFFLGFBQWE7WUFDdkIsNnpHQUF5Qzs7U0FFNUMsQ0FBQztPQUNXLGtCQUFrQixDQTZFOUI7SUFBRCx5QkFBQztDQUFBLEFBN0VELElBNkVDO1NBN0VZLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQWZ0ZXJWaWV3SW5pdCxcbiAgICBDb21wb25lbnQsXG4gICAgRWxlbWVudFJlZixcbiAgICBJbnB1dCxcbiAgICBWaWV3Q2hpbGQsXG4gICAgT25EZXN0cm95LFxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBmcm9tLCBTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xuXG5pbXBvcnQgeyBUaHVtYm5haWxTaXplIH0gZnJvbSBcIi4vdGh1bWJuYWlsLXNpemVcIjtcbmltcG9ydCB7IFRodW1ibmFpbFNlcnZpY2UgfSBmcm9tIFwiLi90aHVtYm5haWwuc2VydmljZVwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJzLXRodW1ibmFpbFwiLFxuICAgIHRlbXBsYXRlVXJsOiBcIi4vdGh1bWJuYWlsLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL3RodW1ibmFpbC5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgVGh1bWJuYWlsQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCwgT25EZXN0cm95IHtcbiAgICBwcml2YXRlIHN0YXRpYyBuZXh0SWQgPSAwO1xuICAgIHB1YmxpYyBmYWxsYmFjayA9IGZhbHNlO1xuICAgIHB1YmxpYyBvcmllbnRhdGlvbjogbnVtYmVyO1xuXG4gICAgQFZpZXdDaGlsZChcImltZ1wiLCB7IHN0YXRpYzogZmFsc2UgfSlcbiAgICBwdWJsaWMgaW1nRWw6IEVsZW1lbnRSZWY7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpZCA9IGBzLXRodW1ibmFpbC0ke1RodW1ibmFpbENvbXBvbmVudC5nZXROZXh0SWQoKX1gO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgc2l6ZTogVGh1bWJuYWlsU2l6ZSA9IFRodW1ibmFpbFNpemUuTWVkaXVtO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaW1hZ2VTb3VyY2U6IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGltYWdlRmFsbGJhY2s/OiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpbWFnZUFsdDogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaWNvbkNsYXNzID0gXCJmYXIgZmEtaW1hZ2VcIjtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGhhc0FjdGlvbiA9IGZhbHNlO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgYWN0aW9uSWNvbkNsYXNzID0gXCJmYXMgZmEtY2FtZXJhXCI7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpc1RpbGUgPSBmYWxzZTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGlzQnJhbmQgPSBmYWxzZTtcblxuICAgIHByaXZhdGUgcmVhZG9ubHkgbmdVbnN1YnNjcmliZSA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHRodW1ibmFpbFNlcnZpY2U6IFRodW1ibmFpbFNlcnZpY2UpIHsgfVxuXG4gICAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLm5nVW5zdWJzY3JpYmUubmV4dCgpO1xuICAgICAgICB0aGlzLm5nVW5zdWJzY3JpYmUuY29tcGxldGUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5pbWdFbCkge1xuICAgICAgICAgICAgdGhpcy5pbWdFbC5uYXRpdmVFbGVtZW50LmFkZEV2ZW50TGlzdGVuZXIoXCJsb2FkXCIsICgpID0+IHtcbiAgICAgICAgICAgICAgICBmcm9tKHRoaXMudGh1bWJuYWlsU2VydmljZS5nZXRCaW5hcnlGaWxlKHRoaXMuaW1nRWwubmF0aXZlRWxlbWVudCkpXG4gICAgICAgICAgICAgICAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLm5nVW5zdWJzY3JpYmUpKVxuICAgICAgICAgICAgICAgICAgICAuc3Vic2NyaWJlKChvcmllbnRhdGlvbjogbnVtYmVyKSA9PiAodGhpcy5vcmllbnRhdGlvbiA9IG9yaWVudGF0aW9uKSk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuXG4gICAgcHJpdmF0ZSBzdGF0aWMgZ2V0TmV4dElkKCk6IG51bWJlciB7XG4gICAgICAgIGNvbnN0IGlkID0gVGh1bWJuYWlsQ29tcG9uZW50Lm5leHRJZDtcbiAgICAgICAgVGh1bWJuYWlsQ29tcG9uZW50Lm5leHRJZCsrO1xuICAgICAgICByZXR1cm4gaWQ7XG4gICAgfVxuXG4gICAgcHVibGljIGdldEltYWdlQWx0VGV4dCgpOiBzdHJpbmcge1xuICAgICAgICBjb25zdCBhbHRUZXh0ID0gdGhpcy5pbWFnZUFsdCB8fCAnJztcbiAgICAgICAgLy8gUmVtb3ZlIGEgcGFsYXZyYSBcImltYWdlXCIgb3UgXCJpbWFnZW1cIiBwYXJhIGV2aXRhciByZWR1bmTDom5jaWFcbiAgICAgICAgcmV0dXJuIGFsdFRleHQucmVwbGFjZSgvXFxiaW1hZ2VcXGIvZ2ksICcnKS5yZXBsYWNlKC9cXGJpbWFnZW1cXGIvZ2ksICcnKS50cmltKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uSW1hZ2VFcnJvcigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5mYWxsYmFjayA9IHRydWU7XG4gICAgfVxuXG4gICAgcHVibGljIG9uRmFsbGJhY2tFcnJvcigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbWFnZUZhbGxiYWNrID0gbnVsbDtcbiAgICB9XG59XG4iXX0=