@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.
- package/bundles/senior-gestao-empresarial-angular-components.umd.js +843 -220
- package/bundles/senior-gestao-empresarial-angular-components.umd.js.map +1 -1
- package/bundles/senior-gestao-empresarial-angular-components.umd.min.js +2 -2
- package/bundles/senior-gestao-empresarial-angular-components.umd.min.js.map +1 -1
- package/components/object-card/elements/field/object-card-field.component.d.ts +18 -0
- package/components/object-card/elements/main/object-card-main.component.d.ts +37 -0
- package/components/object-card/index.d.ts +4 -0
- package/components/object-card/object-card.component.d.ts +29 -0
- package/components/object-card/object-card.module.d.ts +2 -0
- package/components/shared/border-button/border-button.component.d.ts +7 -0
- package/components/shared/border-button/border-button.module.d.ts +2 -0
- package/components/shared/models/border-button-options.d.ts +9 -0
- package/components/shared/models/enum-severity.d.ts +7 -0
- package/components/thumbnail/index.d.ts +3 -0
- package/components/thumbnail/thumbnail-size.d.ts +5 -0
- package/components/thumbnail/thumbnail.component.d.ts +28 -0
- package/components/thumbnail/thumbnail.module.d.ts +2 -0
- package/components/thumbnail/thumbnail.service.d.ts +21 -0
- package/esm2015/components/object-card/elements/field/object-card-field.component.js +58 -0
- package/esm2015/components/object-card/elements/main/object-card-main.component.js +142 -0
- package/esm2015/components/object-card/index.js +5 -0
- package/esm2015/components/object-card/object-card.component.js +142 -0
- package/esm2015/components/object-card/object-card.module.js +22 -0
- package/esm2015/components/shared/border-button/border-button.component.js +24 -0
- package/esm2015/components/shared/border-button/border-button.module.js +16 -0
- package/esm2015/components/shared/models/border-button-options.js +1 -0
- package/esm2015/components/shared/models/enum-severity.js +9 -0
- package/esm2015/components/thumbnail/index.js +4 -0
- package/esm2015/components/thumbnail/thumbnail-size.js +7 -0
- package/esm2015/components/thumbnail/thumbnail.component.js +96 -0
- package/esm2015/components/thumbnail/thumbnail.module.js +17 -0
- package/esm2015/components/thumbnail/thumbnail.service.js +90 -0
- package/esm2015/public-api.js +3 -1
- package/esm2015/senior-gestao-empresarial-angular-components.js +8 -5
- package/esm5/components/object-card/elements/field/object-card-field.component.js +60 -0
- package/esm5/components/object-card/elements/main/object-card-main.component.js +167 -0
- package/esm5/components/object-card/index.js +5 -0
- package/esm5/components/object-card/object-card.component.js +144 -0
- package/esm5/components/object-card/object-card.module.js +25 -0
- package/esm5/components/shared/border-button/border-button.component.js +25 -0
- package/esm5/components/shared/border-button/border-button.module.js +19 -0
- package/esm5/components/shared/models/border-button-options.js +1 -0
- package/esm5/components/shared/models/enum-severity.js +9 -0
- package/esm5/components/thumbnail/index.js +4 -0
- package/esm5/components/thumbnail/thumbnail-size.js +7 -0
- package/esm5/components/thumbnail/thumbnail.component.js +99 -0
- package/esm5/components/thumbnail/thumbnail.module.js +20 -0
- package/esm5/components/thumbnail/thumbnail.service.js +95 -0
- package/esm5/public-api.js +3 -1
- package/esm5/senior-gestao-empresarial-angular-components.js +8 -5
- package/fesm2015/senior-gestao-empresarial-angular-components.js +737 -167
- package/fesm2015/senior-gestao-empresarial-angular-components.js.map +1 -1
- package/fesm5/senior-gestao-empresarial-angular-components.js +835 -218
- package/fesm5/senior-gestao-empresarial-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/senior-gestao-empresarial-angular-components.d.ts +7 -4
- package/senior-gestao-empresarial-angular-components.metadata.json +1 -1
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { EventEmitter, TemplateRef } from "@angular/core";
|
|
2
|
+
import { MenuItem } from "primeng/api";
|
|
3
|
+
import { ThumbnailComponent } from "../../../thumbnail/thumbnail.component";
|
|
4
|
+
export declare class ObjectCardFieldComponent {
|
|
5
|
+
private static nextId;
|
|
6
|
+
id: string;
|
|
7
|
+
imageSource?: string;
|
|
8
|
+
imageAlt?: string;
|
|
9
|
+
iconClass?: string;
|
|
10
|
+
label?: string;
|
|
11
|
+
description?: string;
|
|
12
|
+
buttonLabel?: string;
|
|
13
|
+
buttonModel?: MenuItem[];
|
|
14
|
+
buttonClick: EventEmitter<any>;
|
|
15
|
+
thumbnailComponent: ThumbnailComponent;
|
|
16
|
+
content: TemplateRef<any>;
|
|
17
|
+
private static getNextId;
|
|
18
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { AfterContentInit, EventEmitter } from "@angular/core";
|
|
2
|
+
import { MenuItem } from "primeng/api";
|
|
3
|
+
import { Observable } from "rxjs";
|
|
4
|
+
import { ThumbnailSize } from "../../../thumbnail/thumbnail-size";
|
|
5
|
+
import { ThumbnailComponent } from "../../../thumbnail/thumbnail.component";
|
|
6
|
+
export declare class ObjectCardMainComponent implements AfterContentInit {
|
|
7
|
+
private static nextId;
|
|
8
|
+
id: string;
|
|
9
|
+
imageSource?: string;
|
|
10
|
+
imageFallback?: string;
|
|
11
|
+
imageAlt?: string;
|
|
12
|
+
iconClass: string;
|
|
13
|
+
hasThumbnail: boolean;
|
|
14
|
+
hasDescription: boolean;
|
|
15
|
+
isBrand: boolean;
|
|
16
|
+
expandableImage: boolean;
|
|
17
|
+
imageLoader?: () => Observable<string> | Promise<string>;
|
|
18
|
+
label?: string;
|
|
19
|
+
description?: string;
|
|
20
|
+
buttonLabel?: string;
|
|
21
|
+
buttonModel?: MenuItem[];
|
|
22
|
+
buttonClick: EventEmitter<any>;
|
|
23
|
+
thumbnailComponent: ThumbnailComponent;
|
|
24
|
+
showImageModal: boolean;
|
|
25
|
+
fullImageSource?: string;
|
|
26
|
+
loadingFullImage: boolean;
|
|
27
|
+
private _thumbnailSize;
|
|
28
|
+
set thumbnailSize(value: ThumbnailSize);
|
|
29
|
+
get thumbnailSize(): ThumbnailSize;
|
|
30
|
+
onResize(): void;
|
|
31
|
+
ngAfterContentInit(): void;
|
|
32
|
+
update(): void;
|
|
33
|
+
private static getNextId;
|
|
34
|
+
getImageAltText(): string;
|
|
35
|
+
openImageModal(): Promise<void>;
|
|
36
|
+
private resolveFullImageSource;
|
|
37
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { AfterContentChecked, EventEmitter, QueryList } from "@angular/core";
|
|
2
|
+
import { BorderButtonOptions } from "../shared/models/border-button-options";
|
|
3
|
+
import { EnumSeverity } from "../shared/models/enum-severity";
|
|
4
|
+
import { ObjectCardFieldComponent } from "./elements/field/object-card-field.component";
|
|
5
|
+
import { ObjectCardMainComponent } from "./elements/main/object-card-main.component";
|
|
6
|
+
export declare class ObjectCardComponent implements AfterContentChecked {
|
|
7
|
+
private static nextId;
|
|
8
|
+
id: string;
|
|
9
|
+
expanded: boolean;
|
|
10
|
+
expandTooltip: string;
|
|
11
|
+
collapseTooltip: string;
|
|
12
|
+
fieldsMinWidth: number;
|
|
13
|
+
expandedChange: EventEmitter<boolean>;
|
|
14
|
+
main: ObjectCardMainComponent;
|
|
15
|
+
fields?: QueryList<ObjectCardFieldComponent>;
|
|
16
|
+
maxVisibleFields: number;
|
|
17
|
+
severity: EnumSeverity;
|
|
18
|
+
borderButtonOptions: BorderButtonOptions;
|
|
19
|
+
readonly EnumSeverity: typeof EnumSeverity;
|
|
20
|
+
private readonly container;
|
|
21
|
+
private readonly cardMainContainer;
|
|
22
|
+
private readonly iconContainer;
|
|
23
|
+
ngAfterContentChecked(): void;
|
|
24
|
+
private update;
|
|
25
|
+
toggle(): void;
|
|
26
|
+
expand(): void;
|
|
27
|
+
collapse(): void;
|
|
28
|
+
private static getNextId;
|
|
29
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { BorderButtonOptions } from "../models/border-button-options";
|
|
2
|
+
import { EnumSeverity } from "../models/enum-severity";
|
|
3
|
+
export declare class BorderButtonComponent {
|
|
4
|
+
severity: EnumSeverity;
|
|
5
|
+
options: BorderButtonOptions;
|
|
6
|
+
readonly EnumSeverity: typeof EnumSeverity;
|
|
7
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { EnumSeverity } from "./enum-severity";
|
|
2
|
+
export declare type BorderButtonOptions = {
|
|
3
|
+
label: (severity: EnumSeverity) => string;
|
|
4
|
+
onClick?: (severity: EnumSeverity) => void;
|
|
5
|
+
visible?: (severity: EnumSeverity) => boolean;
|
|
6
|
+
disabled?: (severity: EnumSeverity) => boolean;
|
|
7
|
+
tooltip?: (severity: EnumSeverity) => string;
|
|
8
|
+
icon?: (severity: EnumSeverity) => string;
|
|
9
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { AfterViewInit, ElementRef, OnDestroy } from "@angular/core";
|
|
2
|
+
import { ThumbnailSize } from "./thumbnail-size";
|
|
3
|
+
import { ThumbnailService } from "./thumbnail.service";
|
|
4
|
+
export declare class ThumbnailComponent implements AfterViewInit, OnDestroy {
|
|
5
|
+
private readonly thumbnailService;
|
|
6
|
+
private static nextId;
|
|
7
|
+
fallback: boolean;
|
|
8
|
+
orientation: number;
|
|
9
|
+
imgEl: ElementRef;
|
|
10
|
+
id: string;
|
|
11
|
+
size: ThumbnailSize;
|
|
12
|
+
imageSource: string;
|
|
13
|
+
imageFallback?: string;
|
|
14
|
+
imageAlt: string;
|
|
15
|
+
iconClass: string;
|
|
16
|
+
hasAction: boolean;
|
|
17
|
+
actionIconClass: string;
|
|
18
|
+
isTile: boolean;
|
|
19
|
+
isBrand: boolean;
|
|
20
|
+
private readonly ngUnsubscribe;
|
|
21
|
+
constructor(thumbnailService: ThumbnailService);
|
|
22
|
+
ngOnDestroy(): void;
|
|
23
|
+
ngAfterViewInit(): void;
|
|
24
|
+
private static getNextId;
|
|
25
|
+
getImageAltText(): string;
|
|
26
|
+
onImageError(): void;
|
|
27
|
+
onFallbackError(): void;
|
|
28
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare class ThumbnailService {
|
|
2
|
+
private static readonly HTTP_STATUS_OK;
|
|
3
|
+
private static readonly JPEG_MARKER;
|
|
4
|
+
private static readonly EXIF_MARKER;
|
|
5
|
+
private static readonly EXIF_SIGNATURE;
|
|
6
|
+
private static readonly LITTLE_ENDIAN_MARKER;
|
|
7
|
+
private static readonly ORIENTATION_TAG;
|
|
8
|
+
private static readonly MARKER_MASK;
|
|
9
|
+
private static readonly NOT_DEFINED;
|
|
10
|
+
private static readonly NOT_JPEG;
|
|
11
|
+
private static readonly INITIAL_OFFSET;
|
|
12
|
+
private static readonly EXIF_OFFSET;
|
|
13
|
+
private static readonly TAG_SIZE;
|
|
14
|
+
private static readonly TAG_VALUE_OFFSET;
|
|
15
|
+
getBinaryFile(img: HTMLImageElement): Promise<unknown>;
|
|
16
|
+
/**
|
|
17
|
+
* Retorna a tag da orientação EXIF {-1} Não definido, {-2} Não é formato JPEG, {1, 2, 3, 4, 5, 6, 7, 8} valores da orientação.
|
|
18
|
+
*/
|
|
19
|
+
private getOrientation;
|
|
20
|
+
private extractOrientationFromExif;
|
|
21
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
var ObjectCardFieldComponent_1;
|
|
2
|
+
import { __decorate } from "tslib";
|
|
3
|
+
import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef, ViewChild } from "@angular/core";
|
|
4
|
+
import { ThumbnailComponent } from "../../../thumbnail/thumbnail.component";
|
|
5
|
+
let ObjectCardFieldComponent = ObjectCardFieldComponent_1 = class ObjectCardFieldComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.id = `erp-object-card-field-${ObjectCardFieldComponent_1.getNextId()}`;
|
|
8
|
+
this.buttonClick = new EventEmitter();
|
|
9
|
+
}
|
|
10
|
+
static getNextId() {
|
|
11
|
+
const id = ObjectCardFieldComponent_1.nextId;
|
|
12
|
+
ObjectCardFieldComponent_1.nextId++;
|
|
13
|
+
return id;
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
ObjectCardFieldComponent.nextId = 0;
|
|
17
|
+
__decorate([
|
|
18
|
+
Input()
|
|
19
|
+
], ObjectCardFieldComponent.prototype, "id", void 0);
|
|
20
|
+
__decorate([
|
|
21
|
+
Input()
|
|
22
|
+
], ObjectCardFieldComponent.prototype, "imageSource", void 0);
|
|
23
|
+
__decorate([
|
|
24
|
+
Input()
|
|
25
|
+
], ObjectCardFieldComponent.prototype, "imageAlt", void 0);
|
|
26
|
+
__decorate([
|
|
27
|
+
Input()
|
|
28
|
+
], ObjectCardFieldComponent.prototype, "iconClass", void 0);
|
|
29
|
+
__decorate([
|
|
30
|
+
Input()
|
|
31
|
+
], ObjectCardFieldComponent.prototype, "label", void 0);
|
|
32
|
+
__decorate([
|
|
33
|
+
Input()
|
|
34
|
+
], ObjectCardFieldComponent.prototype, "description", void 0);
|
|
35
|
+
__decorate([
|
|
36
|
+
Input()
|
|
37
|
+
], ObjectCardFieldComponent.prototype, "buttonLabel", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
Input()
|
|
40
|
+
], ObjectCardFieldComponent.prototype, "buttonModel", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
Output()
|
|
43
|
+
], ObjectCardFieldComponent.prototype, "buttonClick", void 0);
|
|
44
|
+
__decorate([
|
|
45
|
+
ContentChild(ThumbnailComponent, { static: true })
|
|
46
|
+
], ObjectCardFieldComponent.prototype, "thumbnailComponent", void 0);
|
|
47
|
+
__decorate([
|
|
48
|
+
ViewChild(TemplateRef, { static: true })
|
|
49
|
+
], ObjectCardFieldComponent.prototype, "content", void 0);
|
|
50
|
+
ObjectCardFieldComponent = ObjectCardFieldComponent_1 = __decorate([
|
|
51
|
+
Component({
|
|
52
|
+
selector: "erp-object-card-field",
|
|
53
|
+
template: "<ng-template>\n <div class=\"container\">\n <ng-content select=\"s-thumbnail\"></ng-content>\n <s-thumbnail\n [id]=\"id + '-thumbnail'\"\n *ngIf=\"!thumbnailComponent && (imageSource || iconClass)\"\n [imageSource]=\"imageSource\"\n [imageAlt]=\"imageAlt || label\"\n [iconClass]=\"iconClass\"\n size=\"small\"\n ></s-thumbnail>\n\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 cssClass: 'description',\n elementId: id + '-description',\n templateWrapper: descriptionTemplate,\n text: description\n }\"></ng-container>\n\n <s-button\n *ngIf=\"buttonLabel\"\n [id]=\"id + '-button'\"\n styleClass=\"object-card-button\"\n [label]=\"buttonLabel\"\n priority=\"link\"\n size=\"small\"\n [model]=\"buttonModel\"\n (onClick)=\"buttonClick.emit($event)\"\n ></s-button>\n\n <ng-template\n #textSpan\n let-text=\"text\"\n let-elementId=\"elementId\"\n let-templateWrapper=\"templateWrapper\"\n let-cssClass=\"cssClass\"\n >\n <span\n *ngIf=\"!templateWrapper.children.length\"\n [id]=\"elementId\"\n [pTooltip]=\"text\"\n tooltipPosition=\"top\"\n [class]=\"cssClass\"\n showDelay=\"500\"\n >{{ text }}</span>\n </ng-template>\n </div>\n </div>\n</ng-template>\n",
|
|
54
|
+
styles: [".container{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;height:100%}.info-container{margin-left:10px}.info-container,.info-container span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.info-container .label{color:#999;display:block}.info-container .description{display:block}@media all and (-ms-high-contrast:none),(-ms-high-contrast:active){.info-container{-ms-flex:1;flex:1}}@media (max-width:767px){.info-container,.info-container span{white-space:normal}}.info-container:only-child{margin-left:0}"]
|
|
55
|
+
})
|
|
56
|
+
], ObjectCardFieldComponent);
|
|
57
|
+
export { ObjectCardFieldComponent };
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWNhcmQtZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvci1nZXN0YW8tZW1wcmVzYXJpYWwvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9vYmplY3QtY2FyZC9lbGVtZW50cy9maWVsZC9vYmplY3QtY2FyZC1maWVsZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzdHLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBTzVFLElBQWEsd0JBQXdCLGdDQUFyQyxNQUFhLHdCQUF3QjtJQUFyQztRQUlXLE9BQUUsR0FBRyx5QkFBeUIsMEJBQXdCLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQztRQXdCckUsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBYzVDLENBQUM7SUFMVyxNQUFNLENBQUMsU0FBUztRQUNwQixNQUFNLEVBQUUsR0FBRywwQkFBd0IsQ0FBQyxNQUFNLENBQUM7UUFDM0MsMEJBQXdCLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDbEMsT0FBTyxFQUFFLENBQUM7SUFDZCxDQUFDO0NBQ0osQ0FBQTtBQXpDa0IsK0JBQU0sR0FBRyxDQUFDLENBQUM7QUFHMUI7SUFEQyxLQUFLLEVBQUU7b0RBQ29FO0FBRzVFO0lBREMsS0FBSyxFQUFFOzZEQUNvQjtBQUc1QjtJQURDLEtBQUssRUFBRTswREFDaUI7QUFHekI7SUFEQyxLQUFLLEVBQUU7MkRBQ2tCO0FBRzFCO0lBREMsS0FBSyxFQUFFO3VEQUNjO0FBR3RCO0lBREMsS0FBSyxFQUFFOzZEQUNvQjtBQUc1QjtJQURDLEtBQUssRUFBRTs2REFDb0I7QUFHNUI7SUFEQyxLQUFLLEVBQUU7NkRBQ3dCO0FBR2hDO0lBREMsTUFBTSxFQUFFOzZEQUMrQjtBQUd4QztJQURDLFlBQVksQ0FBQyxrQkFBa0IsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQztvRUFDTDtBQUc5QztJQURDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUM7eURBQ1I7QUFsQ3hCLHdCQUF3QjtJQUxwQyxTQUFTLENBQUM7UUFDUCxRQUFRLEVBQUUsdUJBQXVCO1FBQ2pDLG10RUFBaUQ7O0tBRXBELENBQUM7R0FDVyx3QkFBd0IsQ0EwQ3BDO1NBMUNZLHdCQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFRlbXBsYXRlUmVmLCBWaWV3Q2hpbGQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgTWVudUl0ZW0gfSBmcm9tIFwicHJpbWVuZy9hcGlcIjtcblxuaW1wb3J0IHsgVGh1bWJuYWlsQ29tcG9uZW50IH0gZnJvbSBcIi4uLy4uLy4uL3RodW1ibmFpbC90aHVtYm5haWwuY29tcG9uZW50XCI7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBcImVycC1vYmplY3QtY2FyZC1maWVsZFwiLFxuICAgIHRlbXBsYXRlVXJsOiBcIi4vb2JqZWN0LWNhcmQtZmllbGQuY29tcG9uZW50Lmh0bWxcIixcbiAgICBzdHlsZVVybHM6IFtcIi4vb2JqZWN0LWNhcmQtZmllbGQuY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIE9iamVjdENhcmRGaWVsZENvbXBvbmVudCB7XG4gICAgcHJpdmF0ZSBzdGF0aWMgbmV4dElkID0gMDtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGlkID0gYGVycC1vYmplY3QtY2FyZC1maWVsZC0ke09iamVjdENhcmRGaWVsZENvbXBvbmVudC5nZXROZXh0SWQoKX1gO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaW1hZ2VTb3VyY2U/OiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpbWFnZUFsdD86IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGljb25DbGFzcz86IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGxhYmVsPzogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBidXR0b25MYWJlbD86IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGJ1dHRvbk1vZGVsPzogTWVudUl0ZW1bXTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBidXR0b25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIEBDb250ZW50Q2hpbGQoVGh1bWJuYWlsQ29tcG9uZW50LCB7IHN0YXRpYzogdHJ1ZSB9KVxuICAgIHB1YmxpYyB0aHVtYm5haWxDb21wb25lbnQ6IFRodW1ibmFpbENvbXBvbmVudDtcblxuICAgIEBWaWV3Q2hpbGQoVGVtcGxhdGVSZWYsIHsgc3RhdGljOiB0cnVlIH0pXG4gICAgcHVibGljIGNvbnRlbnQ6IFRlbXBsYXRlUmVmPGFueT47XG5cblxuICAgIHByaXZhdGUgc3RhdGljIGdldE5leHRJZCgpOiBudW1iZXIge1xuICAgICAgICBjb25zdCBpZCA9IE9iamVjdENhcmRGaWVsZENvbXBvbmVudC5uZXh0SWQ7XG4gICAgICAgIE9iamVjdENhcmRGaWVsZENvbXBvbmVudC5uZXh0SWQrKztcbiAgICAgICAgcmV0dXJuIGlkO1xuICAgIH1cbn1cblxuXG4iXX0=
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
var ObjectCardMainComponent_1;
|
|
2
|
+
import { __awaiter, __decorate } from "tslib";
|
|
3
|
+
import { Component, ContentChild, EventEmitter, HostListener, Input, Output } from "@angular/core";
|
|
4
|
+
import { ThumbnailSize } from "../../../thumbnail/thumbnail-size";
|
|
5
|
+
import { ThumbnailComponent } from "../../../thumbnail/thumbnail.component";
|
|
6
|
+
import { Breakpoints } from "../../../utils";
|
|
7
|
+
let ObjectCardMainComponent = ObjectCardMainComponent_1 = class ObjectCardMainComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.id = `erp-object-card-main-${ObjectCardMainComponent_1.getNextId()}`;
|
|
10
|
+
this.iconClass = "fa fa-picture-o";
|
|
11
|
+
this.hasThumbnail = true;
|
|
12
|
+
this.hasDescription = true;
|
|
13
|
+
this.isBrand = false;
|
|
14
|
+
this.expandableImage = false;
|
|
15
|
+
this.buttonClick = new EventEmitter();
|
|
16
|
+
this.showImageModal = false;
|
|
17
|
+
this.loadingFullImage = false;
|
|
18
|
+
this._thumbnailSize = ThumbnailSize.Medium;
|
|
19
|
+
}
|
|
20
|
+
set thumbnailSize(value) {
|
|
21
|
+
this._thumbnailSize = value;
|
|
22
|
+
if (this.thumbnailComponent) {
|
|
23
|
+
this.thumbnailComponent.size = value;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
get thumbnailSize() {
|
|
27
|
+
return this._thumbnailSize;
|
|
28
|
+
}
|
|
29
|
+
onResize() {
|
|
30
|
+
this.update();
|
|
31
|
+
}
|
|
32
|
+
ngAfterContentInit() {
|
|
33
|
+
this.update();
|
|
34
|
+
}
|
|
35
|
+
update() {
|
|
36
|
+
const windowWidth = window.innerWidth;
|
|
37
|
+
if (windowWidth <= Breakpoints.SM_MAX) {
|
|
38
|
+
this.thumbnailSize = ThumbnailSize.Small;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
this.thumbnailSize = ThumbnailSize.Medium;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
static getNextId() {
|
|
45
|
+
const id = ObjectCardMainComponent_1.nextId;
|
|
46
|
+
ObjectCardMainComponent_1.nextId++;
|
|
47
|
+
return id;
|
|
48
|
+
}
|
|
49
|
+
getImageAltText() {
|
|
50
|
+
const altText = this.imageAlt || this.label || '';
|
|
51
|
+
return altText.replace(/\bimage\b/gi, '').replace(/\bimagem\b/gi, '').trim();
|
|
52
|
+
}
|
|
53
|
+
openImageModal() {
|
|
54
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
+
if (!this.expandableImage || !this.imageSource) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
this.showImageModal = true;
|
|
59
|
+
this.fullImageSource = yield this.resolveFullImageSource();
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
resolveFullImageSource() {
|
|
63
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
+
if (!this.imageLoader || this.fullImageSource) {
|
|
65
|
+
return this.fullImageSource || this.imageSource;
|
|
66
|
+
}
|
|
67
|
+
this.loadingFullImage = true;
|
|
68
|
+
try {
|
|
69
|
+
const result = this.imageLoader();
|
|
70
|
+
return yield (result instanceof Promise ? result : result.toPromise());
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
console.error('Erro ao carregar imagem completa:', error);
|
|
74
|
+
return this.imageSource;
|
|
75
|
+
}
|
|
76
|
+
finally {
|
|
77
|
+
this.loadingFullImage = false;
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
ObjectCardMainComponent.nextId = 0;
|
|
83
|
+
__decorate([
|
|
84
|
+
Input()
|
|
85
|
+
], ObjectCardMainComponent.prototype, "id", void 0);
|
|
86
|
+
__decorate([
|
|
87
|
+
Input()
|
|
88
|
+
], ObjectCardMainComponent.prototype, "imageSource", void 0);
|
|
89
|
+
__decorate([
|
|
90
|
+
Input()
|
|
91
|
+
], ObjectCardMainComponent.prototype, "imageFallback", void 0);
|
|
92
|
+
__decorate([
|
|
93
|
+
Input()
|
|
94
|
+
], ObjectCardMainComponent.prototype, "imageAlt", void 0);
|
|
95
|
+
__decorate([
|
|
96
|
+
Input()
|
|
97
|
+
], ObjectCardMainComponent.prototype, "iconClass", void 0);
|
|
98
|
+
__decorate([
|
|
99
|
+
Input()
|
|
100
|
+
], ObjectCardMainComponent.prototype, "hasThumbnail", void 0);
|
|
101
|
+
__decorate([
|
|
102
|
+
Input()
|
|
103
|
+
], ObjectCardMainComponent.prototype, "hasDescription", void 0);
|
|
104
|
+
__decorate([
|
|
105
|
+
Input()
|
|
106
|
+
], ObjectCardMainComponent.prototype, "isBrand", void 0);
|
|
107
|
+
__decorate([
|
|
108
|
+
Input()
|
|
109
|
+
], ObjectCardMainComponent.prototype, "expandableImage", void 0);
|
|
110
|
+
__decorate([
|
|
111
|
+
Input()
|
|
112
|
+
], ObjectCardMainComponent.prototype, "imageLoader", void 0);
|
|
113
|
+
__decorate([
|
|
114
|
+
Input()
|
|
115
|
+
], ObjectCardMainComponent.prototype, "label", void 0);
|
|
116
|
+
__decorate([
|
|
117
|
+
Input()
|
|
118
|
+
], ObjectCardMainComponent.prototype, "description", void 0);
|
|
119
|
+
__decorate([
|
|
120
|
+
Input()
|
|
121
|
+
], ObjectCardMainComponent.prototype, "buttonLabel", void 0);
|
|
122
|
+
__decorate([
|
|
123
|
+
Input()
|
|
124
|
+
], ObjectCardMainComponent.prototype, "buttonModel", void 0);
|
|
125
|
+
__decorate([
|
|
126
|
+
Output()
|
|
127
|
+
], ObjectCardMainComponent.prototype, "buttonClick", void 0);
|
|
128
|
+
__decorate([
|
|
129
|
+
ContentChild(ThumbnailComponent, { static: true })
|
|
130
|
+
], ObjectCardMainComponent.prototype, "thumbnailComponent", void 0);
|
|
131
|
+
__decorate([
|
|
132
|
+
HostListener("window:resize")
|
|
133
|
+
], ObjectCardMainComponent.prototype, "onResize", null);
|
|
134
|
+
ObjectCardMainComponent = ObjectCardMainComponent_1 = __decorate([
|
|
135
|
+
Component({
|
|
136
|
+
selector: "erp-object-card-main",
|
|
137
|
+
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",
|
|
138
|
+
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}"]
|
|
139
|
+
})
|
|
140
|
+
], ObjectCardMainComponent);
|
|
141
|
+
export { ObjectCardMainComponent };
|
|
142
|
+
//# 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,142 @@
|
|
|
1
|
+
var ObjectCardComponent_1;
|
|
2
|
+
import { __decorate } from "tslib";
|
|
3
|
+
import { animate, state, style, transition, trigger } from "@angular/animations";
|
|
4
|
+
import { Component, ContentChild, ContentChildren, EventEmitter, Input, Output, ViewChild } from "@angular/core";
|
|
5
|
+
import { EnumSeverity } from "../shared/models/enum-severity";
|
|
6
|
+
import { Breakpoints } from "../utils/breakpoints";
|
|
7
|
+
import { ObjectCardFieldComponent } from "./elements/field/object-card-field.component";
|
|
8
|
+
import { ObjectCardMainComponent } from "./elements/main/object-card-main.component";
|
|
9
|
+
let ObjectCardComponent = ObjectCardComponent_1 = class ObjectCardComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.id = `erp-object-card-${ObjectCardComponent_1.getNextId()}`;
|
|
12
|
+
this.expanded = false;
|
|
13
|
+
this.expandTooltip = "Abrir painel";
|
|
14
|
+
this.collapseTooltip = "Fechar painel";
|
|
15
|
+
this.fieldsMinWidth = 200;
|
|
16
|
+
this.expandedChange = new EventEmitter();
|
|
17
|
+
this.maxVisibleFields = 0;
|
|
18
|
+
this.severity = EnumSeverity.Default;
|
|
19
|
+
this.EnumSeverity = EnumSeverity;
|
|
20
|
+
}
|
|
21
|
+
ngAfterContentChecked() {
|
|
22
|
+
this.update();
|
|
23
|
+
}
|
|
24
|
+
update() {
|
|
25
|
+
const windowWidth = window.innerWidth;
|
|
26
|
+
const containerWidth = this.container.nativeElement.getBoundingClientRect().width;
|
|
27
|
+
const mainFieldWidth = this.cardMainContainer.nativeElement.getBoundingClientRect().width;
|
|
28
|
+
let remainingSpace = containerWidth - mainFieldWidth;
|
|
29
|
+
const fieldsMinWidth = this.fieldsMinWidth;
|
|
30
|
+
const expandIconWidth = this.iconContainer.nativeElement.getBoundingClientRect().width;
|
|
31
|
+
let maxFieldQtd;
|
|
32
|
+
if (windowWidth <= Breakpoints.SM_MAX) {
|
|
33
|
+
maxFieldQtd = 0;
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
maxFieldQtd = Math.floor((remainingSpace) / fieldsMinWidth);
|
|
37
|
+
}
|
|
38
|
+
const 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
|
+
toggle() {
|
|
53
|
+
this.expanded ? this.collapse() : this.expand();
|
|
54
|
+
}
|
|
55
|
+
expand() {
|
|
56
|
+
this.expanded = true;
|
|
57
|
+
this.expandedChange.emit(this.expanded);
|
|
58
|
+
}
|
|
59
|
+
collapse() {
|
|
60
|
+
this.expanded = false;
|
|
61
|
+
this.expandedChange.emit(this.expanded);
|
|
62
|
+
}
|
|
63
|
+
static getNextId() {
|
|
64
|
+
const id = ObjectCardComponent_1.nextId;
|
|
65
|
+
ObjectCardComponent_1.nextId++;
|
|
66
|
+
return id;
|
|
67
|
+
}
|
|
68
|
+
};
|
|
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
|
+
export { ObjectCardComponent };
|
|
142
|
+
//# 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"]}
|