@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,22 @@
|
|
|
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
|
+
let ErpObjectCardModule = class ErpObjectCardModule {
|
|
13
|
+
};
|
|
14
|
+
ErpObjectCardModule = __decorate([
|
|
15
|
+
NgModule({
|
|
16
|
+
imports: [CommonModule, TooltipModule, DialogModule, ThumbnailModule, ButtonModule, LoadingStateModule, BorderButtonModule],
|
|
17
|
+
declarations: [ObjectCardComponent, ObjectCardMainComponent, ObjectCardFieldComponent],
|
|
18
|
+
exports: [ThumbnailModule, ObjectCardComponent, ObjectCardMainComponent, ObjectCardFieldComponent],
|
|
19
|
+
})
|
|
20
|
+
], ErpObjectCardModule);
|
|
21
|
+
export { ErpObjectCardModule };
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWNhcmQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvci1nZXN0YW8tZW1wcmVzYXJpYWwvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9vYmplY3QtY2FyZC9vYmplY3QtY2FyZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNoRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDOUMsT0FBTyxFQUFFLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRXRGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNyRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUN4RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQU9sRixJQUFhLG1CQUFtQixHQUFoQyxNQUFhLG1CQUFtQjtDQUFHLENBQUE7QUFBdEIsbUJBQW1CO0lBTC9CLFFBQVEsQ0FBQztRQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLGVBQWUsRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLENBQUM7UUFDM0gsWUFBWSxFQUFFLENBQUMsbUJBQW1CLEVBQUUsdUJBQXVCLEVBQUUsd0JBQXdCLENBQUM7UUFDdEYsT0FBTyxFQUFFLENBQUMsZUFBZSxFQUFFLG1CQUFtQixFQUFFLHVCQUF1QixFQUFFLHdCQUF3QixDQUFDO0tBQ3JHLENBQUM7R0FDVyxtQkFBbUIsQ0FBRztTQUF0QixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBUb29sdGlwTW9kdWxlIH0gZnJvbSBcInByaW1lbmcvdG9vbHRpcFwiO1xuaW1wb3J0IHsgRGlhbG9nTW9kdWxlIH0gZnJvbSBcInByaW1lbmcvZGlhbG9nXCI7XG5pbXBvcnQgeyBCdXR0b25Nb2R1bGUsIExvYWRpbmdTdGF0ZU1vZHVsZSB9IGZyb20gXCJAc2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzXCI7XG5cbmltcG9ydCB7IFRodW1ibmFpbE1vZHVsZSB9IGZyb20gXCIuLi90aHVtYm5haWwvdGh1bWJuYWlsLm1vZHVsZVwiO1xuaW1wb3J0IHsgT2JqZWN0Q2FyZENvbXBvbmVudCB9IGZyb20gXCIuL29iamVjdC1jYXJkLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgT2JqZWN0Q2FyZE1haW5Db21wb25lbnQgfSBmcm9tIFwiLi9lbGVtZW50cy9tYWluL29iamVjdC1jYXJkLW1haW4uY29tcG9uZW50XCI7XG5pbXBvcnQgeyBPYmplY3RDYXJkRmllbGRDb21wb25lbnQgfSBmcm9tIFwiLi9lbGVtZW50cy9maWVsZC9vYmplY3QtY2FyZC1maWVsZC5jb21wb25lbnRcIjtcbmltcG9ydCB7IEJvcmRlckJ1dHRvbk1vZHVsZSB9IGZyb20gXCIuLi9zaGFyZWQvYm9yZGVyLWJ1dHRvbi9ib3JkZXItYnV0dG9uLm1vZHVsZVwiO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRvb2x0aXBNb2R1bGUsIERpYWxvZ01vZHVsZSwgVGh1bWJuYWlsTW9kdWxlLCBCdXR0b25Nb2R1bGUsIExvYWRpbmdTdGF0ZU1vZHVsZSwgQm9yZGVyQnV0dG9uTW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtPYmplY3RDYXJkQ29tcG9uZW50LCBPYmplY3RDYXJkTWFpbkNvbXBvbmVudCwgT2JqZWN0Q2FyZEZpZWxkQ29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbVGh1bWJuYWlsTW9kdWxlLCBPYmplY3RDYXJkQ29tcG9uZW50LCBPYmplY3RDYXJkTWFpbkNvbXBvbmVudCwgT2JqZWN0Q2FyZEZpZWxkQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgRXJwT2JqZWN0Q2FyZE1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, Input } from "@angular/core";
|
|
3
|
+
import { EnumSeverity } from "../models/enum-severity";
|
|
4
|
+
let BorderButtonComponent = class BorderButtonComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.severity = EnumSeverity.Default;
|
|
7
|
+
this.EnumSeverity = EnumSeverity;
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
__decorate([
|
|
11
|
+
Input()
|
|
12
|
+
], BorderButtonComponent.prototype, "severity", void 0);
|
|
13
|
+
__decorate([
|
|
14
|
+
Input()
|
|
15
|
+
], BorderButtonComponent.prototype, "options", void 0);
|
|
16
|
+
BorderButtonComponent = __decorate([
|
|
17
|
+
Component({
|
|
18
|
+
selector: "s-border-button",
|
|
19
|
+
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",
|
|
20
|
+
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}"]
|
|
21
|
+
})
|
|
22
|
+
], BorderButtonComponent);
|
|
23
|
+
export { BorderButtonComponent };
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9yZGVyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3NoYXJlZC9ib3JkZXItYnV0dG9uL2JvcmRlci1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFPdkQsSUFBYSxxQkFBcUIsR0FBbEMsTUFBYSxxQkFBcUI7SUFBbEM7UUFFSSxhQUFRLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQztRQUt2QixpQkFBWSxHQUFHLFlBQVksQ0FBQztJQUN6QyxDQUFDO0NBQUEsQ0FBQTtBQU5HO0lBREMsS0FBSyxFQUFFO3VEQUN3QjtBQUdoQztJQURDLEtBQUssRUFBRTtzREFDcUI7QUFMcEIscUJBQXFCO0lBTGpDLFNBQVMsQ0FBQztRQUNQLFFBQVEsRUFBRSxpQkFBaUI7UUFDM0IsOGxDQUE2Qzs7S0FFaEQsQ0FBQztHQUNXLHFCQUFxQixDQVFqQztTQVJZLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQm9yZGVyQnV0dG9uT3B0aW9ucyB9IGZyb20gXCIuLi9tb2RlbHMvYm9yZGVyLWJ1dHRvbi1vcHRpb25zXCI7XG5pbXBvcnQgeyBFbnVtU2V2ZXJpdHkgfSBmcm9tIFwiLi4vbW9kZWxzL2VudW0tc2V2ZXJpdHlcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy1ib3JkZXItYnV0dG9uXCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9ib3JkZXItYnV0dG9uLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL2JvcmRlci1idXR0b24uY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIEJvcmRlckJ1dHRvbkNvbXBvbmVudCB7XG4gICAgQElucHV0KClcbiAgICBzZXZlcml0eSA9IEVudW1TZXZlcml0eS5EZWZhdWx0O1xuXG4gICAgQElucHV0KClcbiAgICBvcHRpb25zOiBCb3JkZXJCdXR0b25PcHRpb25zO1xuXG4gICAgcmVhZG9ubHkgRW51bVNldmVyaXR5ID0gRW51bVNldmVyaXR5O1xufVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
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
|
+
let BorderButtonModule = class BorderButtonModule {
|
|
7
|
+
};
|
|
8
|
+
BorderButtonModule = __decorate([
|
|
9
|
+
NgModule({
|
|
10
|
+
imports: [CommonModule, TooltipModule],
|
|
11
|
+
declarations: [BorderButtonComponent],
|
|
12
|
+
exports: [BorderButtonComponent]
|
|
13
|
+
})
|
|
14
|
+
], BorderButtonModule);
|
|
15
|
+
export { BorderButtonModule };
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9yZGVyLWJ1dHRvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3NoYXJlZC9ib3JkZXItYnV0dG9uL2JvcmRlci1idXR0b24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFaEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFPbEUsSUFBYSxrQkFBa0IsR0FBL0IsTUFBYSxrQkFBa0I7Q0FBRyxDQUFBO0FBQXJCLGtCQUFrQjtJQUw5QixRQUFRLENBQUM7UUFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsYUFBYSxDQUFDO1FBQ3RDLFlBQVksRUFBRSxDQUFDLHFCQUFxQixDQUFDO1FBQ3JDLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO0tBQ25DLENBQUM7R0FDVyxrQkFBa0IsQ0FBRztTQUFyQixrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBUb29sdGlwTW9kdWxlIH0gZnJvbSBcInByaW1lbmcvdG9vbHRpcFwiO1xuXG5pbXBvcnQgeyBCb3JkZXJCdXR0b25Db21wb25lbnQgfSBmcm9tIFwiLi9ib3JkZXItYnV0dG9uLmNvbXBvbmVudFwiO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRvb2x0aXBNb2R1bGVdLFxuICAgIGRlY2xhcmF0aW9uczogW0JvcmRlckJ1dHRvbkNvbXBvbmVudF0sXG4gICAgZXhwb3J0czogW0JvcmRlckJ1dHRvbkNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQm9yZGVyQnV0dG9uTW9kdWxlIHt9XG4iXX0=
|
|
@@ -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,96 @@
|
|
|
1
|
+
var ThumbnailComponent_1;
|
|
2
|
+
import { __decorate } from "tslib";
|
|
3
|
+
import { Component, Input, ViewChild, } from "@angular/core";
|
|
4
|
+
import { from, Subject } from "rxjs";
|
|
5
|
+
import { takeUntil } from "rxjs/operators";
|
|
6
|
+
import { ThumbnailSize } from "./thumbnail-size";
|
|
7
|
+
import { ThumbnailService } from "./thumbnail.service";
|
|
8
|
+
let ThumbnailComponent = ThumbnailComponent_1 = class ThumbnailComponent {
|
|
9
|
+
constructor(thumbnailService) {
|
|
10
|
+
this.thumbnailService = thumbnailService;
|
|
11
|
+
this.fallback = false;
|
|
12
|
+
this.id = `s-thumbnail-${ThumbnailComponent_1.getNextId()}`;
|
|
13
|
+
this.size = ThumbnailSize.Medium;
|
|
14
|
+
this.iconClass = "far fa-image";
|
|
15
|
+
this.hasAction = false;
|
|
16
|
+
this.actionIconClass = "fas fa-camera";
|
|
17
|
+
this.isTile = false;
|
|
18
|
+
this.isBrand = false;
|
|
19
|
+
this.ngUnsubscribe = new Subject();
|
|
20
|
+
}
|
|
21
|
+
ngOnDestroy() {
|
|
22
|
+
this.ngUnsubscribe.next();
|
|
23
|
+
this.ngUnsubscribe.complete();
|
|
24
|
+
}
|
|
25
|
+
ngAfterViewInit() {
|
|
26
|
+
if (this.imgEl) {
|
|
27
|
+
this.imgEl.nativeElement.addEventListener("load", () => {
|
|
28
|
+
from(this.thumbnailService.getBinaryFile(this.imgEl.nativeElement))
|
|
29
|
+
.pipe(takeUntil(this.ngUnsubscribe))
|
|
30
|
+
.subscribe((orientation) => (this.orientation = orientation));
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
static getNextId() {
|
|
35
|
+
const id = ThumbnailComponent_1.nextId;
|
|
36
|
+
ThumbnailComponent_1.nextId++;
|
|
37
|
+
return id;
|
|
38
|
+
}
|
|
39
|
+
getImageAltText() {
|
|
40
|
+
const altText = this.imageAlt || '';
|
|
41
|
+
// Remove a palavra "image" ou "imagem" para evitar redundância
|
|
42
|
+
return altText.replace(/\bimage\b/gi, '').replace(/\bimagem\b/gi, '').trim();
|
|
43
|
+
}
|
|
44
|
+
onImageError() {
|
|
45
|
+
this.fallback = true;
|
|
46
|
+
}
|
|
47
|
+
onFallbackError() {
|
|
48
|
+
this.imageFallback = null;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
ThumbnailComponent.nextId = 0;
|
|
52
|
+
ThumbnailComponent.ctorParameters = () => [
|
|
53
|
+
{ type: ThumbnailService }
|
|
54
|
+
];
|
|
55
|
+
__decorate([
|
|
56
|
+
ViewChild("img", { static: false })
|
|
57
|
+
], ThumbnailComponent.prototype, "imgEl", void 0);
|
|
58
|
+
__decorate([
|
|
59
|
+
Input()
|
|
60
|
+
], ThumbnailComponent.prototype, "id", void 0);
|
|
61
|
+
__decorate([
|
|
62
|
+
Input()
|
|
63
|
+
], ThumbnailComponent.prototype, "size", void 0);
|
|
64
|
+
__decorate([
|
|
65
|
+
Input()
|
|
66
|
+
], ThumbnailComponent.prototype, "imageSource", void 0);
|
|
67
|
+
__decorate([
|
|
68
|
+
Input()
|
|
69
|
+
], ThumbnailComponent.prototype, "imageFallback", void 0);
|
|
70
|
+
__decorate([
|
|
71
|
+
Input()
|
|
72
|
+
], ThumbnailComponent.prototype, "imageAlt", void 0);
|
|
73
|
+
__decorate([
|
|
74
|
+
Input()
|
|
75
|
+
], ThumbnailComponent.prototype, "iconClass", void 0);
|
|
76
|
+
__decorate([
|
|
77
|
+
Input()
|
|
78
|
+
], ThumbnailComponent.prototype, "hasAction", void 0);
|
|
79
|
+
__decorate([
|
|
80
|
+
Input()
|
|
81
|
+
], ThumbnailComponent.prototype, "actionIconClass", void 0);
|
|
82
|
+
__decorate([
|
|
83
|
+
Input()
|
|
84
|
+
], ThumbnailComponent.prototype, "isTile", void 0);
|
|
85
|
+
__decorate([
|
|
86
|
+
Input()
|
|
87
|
+
], ThumbnailComponent.prototype, "isBrand", void 0);
|
|
88
|
+
ThumbnailComponent = ThumbnailComponent_1 = __decorate([
|
|
89
|
+
Component({
|
|
90
|
+
selector: "s-thumbnail",
|
|
91
|
+
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",
|
|
92
|
+
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}"]
|
|
93
|
+
})
|
|
94
|
+
], ThumbnailComponent);
|
|
95
|
+
export { ThumbnailComponent };
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3ItZ2VzdGFvLWVtcHJlc2FyaWFsL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvdGh1bWJuYWlsL3RodW1ibmFpbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBRUgsU0FBUyxFQUVULEtBQUssRUFDTCxTQUFTLEdBRVosTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDckMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTNDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQU92RCxJQUFhLGtCQUFrQiwwQkFBL0IsTUFBYSxrQkFBa0I7SUF3QzNCLFlBQTZCLGdCQUFrQztRQUFsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBdEN4RCxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBT2pCLE9BQUUsR0FBRyxlQUFlLG9CQUFrQixDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUM7UUFHckQsU0FBSSxHQUFrQixhQUFhLENBQUMsTUFBTSxDQUFDO1FBWTNDLGNBQVMsR0FBRyxjQUFjLENBQUM7UUFHM0IsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUdsQixvQkFBZSxHQUFHLGVBQWUsQ0FBQztRQUdsQyxXQUFNLEdBQUcsS0FBSyxDQUFDO1FBR2YsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUVOLGtCQUFhLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUVvQixDQUFDO0lBRTdELFdBQVc7UUFDZCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzFCLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVNLGVBQWU7UUFDbEIsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ1osSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRTtnQkFDbkQsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQztxQkFDOUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7cUJBQ25DLFNBQVMsQ0FBQyxDQUFDLFdBQW1CLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUMsQ0FBQyxDQUFDO1lBQzlFLENBQUMsQ0FBQyxDQUFDO1NBQ047SUFDTCxDQUFDO0lBR08sTUFBTSxDQUFDLFNBQVM7UUFDcEIsTUFBTSxFQUFFLEdBQUcsb0JBQWtCLENBQUMsTUFBTSxDQUFDO1FBQ3JDLG9CQUFrQixDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQzVCLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVNLGVBQWU7UUFDbEIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsSUFBSSxFQUFFLENBQUM7UUFDcEMsK0RBQStEO1FBQy9ELE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLGNBQWMsRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNqRixDQUFDO0lBRU0sWUFBWTtRQUNmLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO0lBQ3pCLENBQUM7SUFFTSxlQUFlO1FBQ2xCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO0lBQzlCLENBQUM7Q0FDSixDQUFBO0FBNUVrQix5QkFBTSxHQUFHLENBQUMsQ0FBQzs7WUF1Q3FCLGdCQUFnQjs7QUFsQy9EO0lBREMsU0FBUyxDQUFDLEtBQUssRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQztpREFDWDtBQUd6QjtJQURDLEtBQUssRUFBRTs4Q0FDb0Q7QUFHNUQ7SUFEQyxLQUFLLEVBQUU7Z0RBQzBDO0FBR2xEO0lBREMsS0FBSyxFQUFFO3VEQUNtQjtBQUczQjtJQURDLEtBQUssRUFBRTt5REFDc0I7QUFHOUI7SUFEQyxLQUFLLEVBQUU7b0RBQ2dCO0FBR3hCO0lBREMsS0FBSyxFQUFFO3FEQUMwQjtBQUdsQztJQURDLEtBQUssRUFBRTtxREFDaUI7QUFHekI7SUFEQyxLQUFLLEVBQUU7MkRBQ2lDO0FBR3pDO0lBREMsS0FBSyxFQUFFO2tEQUNjO0FBR3RCO0lBREMsS0FBSyxFQUFFO21EQUNlO0FBcENkLGtCQUFrQjtJQUw5QixTQUFTLENBQUM7UUFDUCxRQUFRLEVBQUUsYUFBYTtRQUN2Qiw2ekdBQXlDOztLQUU1QyxDQUFDO0dBQ1csa0JBQWtCLENBNkU5QjtTQTdFWSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIEFmdGVyVmlld0luaXQsXG4gICAgQ29tcG9uZW50LFxuICAgIEVsZW1lbnRSZWYsXG4gICAgSW5wdXQsXG4gICAgVmlld0NoaWxkLFxuICAgIE9uRGVzdHJveSxcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgZnJvbSwgU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIjtcblxuaW1wb3J0IHsgVGh1bWJuYWlsU2l6ZSB9IGZyb20gXCIuL3RodW1ibmFpbC1zaXplXCI7XG5pbXBvcnQgeyBUaHVtYm5haWxTZXJ2aWNlIH0gZnJvbSBcIi4vdGh1bWJuYWlsLnNlcnZpY2VcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy10aHVtYm5haWxcIixcbiAgICB0ZW1wbGF0ZVVybDogXCIuL3RodW1ibmFpbC5jb21wb25lbnQuaHRtbFwiLFxuICAgIHN0eWxlVXJsczogW1wiLi90aHVtYm5haWwuY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIFRodW1ibmFpbENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XG4gICAgcHJpdmF0ZSBzdGF0aWMgbmV4dElkID0gMDtcbiAgICBwdWJsaWMgZmFsbGJhY2sgPSBmYWxzZTtcbiAgICBwdWJsaWMgb3JpZW50YXRpb246IG51bWJlcjtcblxuICAgIEBWaWV3Q2hpbGQoXCJpbWdcIiwgeyBzdGF0aWM6IGZhbHNlIH0pXG4gICAgcHVibGljIGltZ0VsOiBFbGVtZW50UmVmO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaWQgPSBgcy10aHVtYm5haWwtJHtUaHVtYm5haWxDb21wb25lbnQuZ2V0TmV4dElkKCl9YDtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNpemU6IFRodW1ibmFpbFNpemUgPSBUaHVtYm5haWxTaXplLk1lZGl1bTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGltYWdlU291cmNlOiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpbWFnZUZhbGxiYWNrPzogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaW1hZ2VBbHQ6IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGljb25DbGFzcyA9IFwiZmFyIGZhLWltYWdlXCI7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBoYXNBY3Rpb24gPSBmYWxzZTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGFjdGlvbkljb25DbGFzcyA9IFwiZmFzIGZhLWNhbWVyYVwiO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaXNUaWxlID0gZmFsc2U7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpc0JyYW5kID0gZmFsc2U7XG5cbiAgICBwcml2YXRlIHJlYWRvbmx5IG5nVW5zdWJzY3JpYmUgPSBuZXcgU3ViamVjdCgpO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSB0aHVtYm5haWxTZXJ2aWNlOiBUaHVtYm5haWxTZXJ2aWNlKSB7IH1cblxuICAgIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZ1Vuc3Vic2NyaWJlLm5leHQoKTtcbiAgICAgICAgdGhpcy5uZ1Vuc3Vic2NyaWJlLmNvbXBsZXRlKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuaW1nRWwpIHtcbiAgICAgICAgICAgIHRoaXMuaW1nRWwubmF0aXZlRWxlbWVudC5hZGRFdmVudExpc3RlbmVyKFwibG9hZFwiLCAoKSA9PiB7XG4gICAgICAgICAgICAgICAgZnJvbSh0aGlzLnRodW1ibmFpbFNlcnZpY2UuZ2V0QmluYXJ5RmlsZSh0aGlzLmltZ0VsLm5hdGl2ZUVsZW1lbnQpKVxuICAgICAgICAgICAgICAgICAgICAucGlwZSh0YWtlVW50aWwodGhpcy5uZ1Vuc3Vic2NyaWJlKSlcbiAgICAgICAgICAgICAgICAgICAgLnN1YnNjcmliZSgob3JpZW50YXRpb246IG51bWJlcikgPT4gKHRoaXMub3JpZW50YXRpb24gPSBvcmllbnRhdGlvbikpO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICB9XG5cblxuICAgIHByaXZhdGUgc3RhdGljIGdldE5leHRJZCgpOiBudW1iZXIge1xuICAgICAgICBjb25zdCBpZCA9IFRodW1ibmFpbENvbXBvbmVudC5uZXh0SWQ7XG4gICAgICAgIFRodW1ibmFpbENvbXBvbmVudC5uZXh0SWQrKztcbiAgICAgICAgcmV0dXJuIGlkO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRJbWFnZUFsdFRleHQoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgYWx0VGV4dCA9IHRoaXMuaW1hZ2VBbHQgfHwgJyc7XG4gICAgICAgIC8vIFJlbW92ZSBhIHBhbGF2cmEgXCJpbWFnZVwiIG91IFwiaW1hZ2VtXCIgcGFyYSBldml0YXIgcmVkdW5kw6JuY2lhXG4gICAgICAgIHJldHVybiBhbHRUZXh0LnJlcGxhY2UoL1xcYmltYWdlXFxiL2dpLCAnJykucmVwbGFjZSgvXFxiaW1hZ2VtXFxiL2dpLCAnJykudHJpbSgpO1xuICAgIH1cblxuICAgIHB1YmxpYyBvbkltYWdlRXJyb3IoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZmFsbGJhY2sgPSB0cnVlO1xuICAgIH1cblxuICAgIHB1YmxpYyBvbkZhbGxiYWNrRXJyb3IoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaW1hZ2VGYWxsYmFjayA9IG51bGw7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { NgModule } from "@angular/core";
|
|
4
|
+
import { ThumbnailComponent } from "./thumbnail.component";
|
|
5
|
+
import { ThumbnailService } from "./thumbnail.service";
|
|
6
|
+
let ThumbnailModule = class ThumbnailModule {
|
|
7
|
+
};
|
|
8
|
+
ThumbnailModule = __decorate([
|
|
9
|
+
NgModule({
|
|
10
|
+
imports: [CommonModule],
|
|
11
|
+
declarations: [ThumbnailComponent],
|
|
12
|
+
exports: [ThumbnailComponent],
|
|
13
|
+
providers: [ThumbnailService],
|
|
14
|
+
})
|
|
15
|
+
], ThumbnailModule);
|
|
16
|
+
export { ThumbnailModule };
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlsLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3ItZ2VzdGFvLWVtcHJlc2FyaWFsL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvdGh1bWJuYWlsL3RodW1ibmFpbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBUXZELElBQWEsZUFBZSxHQUE1QixNQUFhLGVBQWU7Q0FBRyxDQUFBO0FBQWxCLGVBQWU7SUFOM0IsUUFBUSxDQUFDO1FBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO1FBQ3ZCLFlBQVksRUFBRSxDQUFDLGtCQUFrQixDQUFDO1FBQ2xDLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDO1FBQzdCLFNBQVMsRUFBRSxDQUFDLGdCQUFnQixDQUFDO0tBQ2hDLENBQUM7R0FDVyxlQUFlLENBQUc7U0FBbEIsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgVGh1bWJuYWlsQ29tcG9uZW50IH0gZnJvbSBcIi4vdGh1bWJuYWlsLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgVGh1bWJuYWlsU2VydmljZSB9IGZyb20gXCIuL3RodW1ibmFpbC5zZXJ2aWNlXCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbVGh1bWJuYWlsQ29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbVGh1bWJuYWlsQ29tcG9uZW50XSxcbiAgICBwcm92aWRlcnM6IFtUaHVtYm5haWxTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgVGh1bWJuYWlsTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
var ThumbnailService_1;
|
|
2
|
+
import { __decorate } from "tslib";
|
|
3
|
+
import { Injectable } from "@angular/core";
|
|
4
|
+
let ThumbnailService = ThumbnailService_1 = class ThumbnailService {
|
|
5
|
+
getBinaryFile(img) {
|
|
6
|
+
return new Promise(resolve => {
|
|
7
|
+
const getOrientation = this.getOrientation.bind(this);
|
|
8
|
+
let http = new XMLHttpRequest();
|
|
9
|
+
http.addEventListener("load", () => {
|
|
10
|
+
if (http.readyState === 4 && (http.status === ThumbnailService_1.HTTP_STATUS_OK || http.status === 0)) {
|
|
11
|
+
const orientation = getOrientation(http.response);
|
|
12
|
+
http = null;
|
|
13
|
+
resolve(orientation);
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
http.addEventListener("error", () => {
|
|
17
|
+
http = null;
|
|
18
|
+
throw new Error("Não foi possível carregar a imagem");
|
|
19
|
+
});
|
|
20
|
+
http.open("GET", img.src, true);
|
|
21
|
+
http.responseType = "arraybuffer";
|
|
22
|
+
http.send(null);
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* 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.
|
|
27
|
+
*/
|
|
28
|
+
getOrientation(file) {
|
|
29
|
+
const view = new DataView(file);
|
|
30
|
+
if (view.getUint16(0, false) !== ThumbnailService_1.JPEG_MARKER) {
|
|
31
|
+
return ThumbnailService_1.NOT_JPEG;
|
|
32
|
+
}
|
|
33
|
+
const length = view.byteLength;
|
|
34
|
+
let offset = ThumbnailService_1.INITIAL_OFFSET;
|
|
35
|
+
while (offset < length) {
|
|
36
|
+
const marker = view.getUint16(offset, false);
|
|
37
|
+
offset += ThumbnailService_1.INITIAL_OFFSET;
|
|
38
|
+
if (marker === ThumbnailService_1.EXIF_MARKER) {
|
|
39
|
+
const orientation = this.extractOrientationFromExif(view, offset);
|
|
40
|
+
if (orientation !== null) {
|
|
41
|
+
return orientation;
|
|
42
|
+
}
|
|
43
|
+
return ThumbnailService_1.NOT_DEFINED;
|
|
44
|
+
}
|
|
45
|
+
// tslint:disable-next-line: no-bitwise
|
|
46
|
+
if ((marker & ThumbnailService_1.MARKER_MASK) !== ThumbnailService_1.MARKER_MASK) {
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
offset += view.getUint16(offset, false);
|
|
50
|
+
}
|
|
51
|
+
return ThumbnailService_1.NOT_DEFINED;
|
|
52
|
+
}
|
|
53
|
+
extractOrientationFromExif(view, initialOffset) {
|
|
54
|
+
let offset = initialOffset;
|
|
55
|
+
offset += ThumbnailService_1.INITIAL_OFFSET;
|
|
56
|
+
if (view.getUint32(offset, false) !== ThumbnailService_1.EXIF_SIGNATURE) {
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
offset += ThumbnailService_1.EXIF_OFFSET;
|
|
60
|
+
const little = view.getUint16(offset, false) === ThumbnailService_1.LITTLE_ENDIAN_MARKER;
|
|
61
|
+
offset += view.getUint32(offset + 4, little);
|
|
62
|
+
const tags = view.getUint16(offset, little);
|
|
63
|
+
offset += ThumbnailService_1.INITIAL_OFFSET;
|
|
64
|
+
for (let i = 0; i < tags; i++) {
|
|
65
|
+
const tagOffset = offset + i * ThumbnailService_1.TAG_SIZE;
|
|
66
|
+
if (view.getUint16(tagOffset, little) === ThumbnailService_1.ORIENTATION_TAG) {
|
|
67
|
+
return view.getUint16(tagOffset + ThumbnailService_1.TAG_VALUE_OFFSET, little);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return null;
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
ThumbnailService.HTTP_STATUS_OK = 200;
|
|
74
|
+
ThumbnailService.JPEG_MARKER = 0xffd8;
|
|
75
|
+
ThumbnailService.EXIF_MARKER = 0xffe1;
|
|
76
|
+
ThumbnailService.EXIF_SIGNATURE = 0x45786966;
|
|
77
|
+
ThumbnailService.LITTLE_ENDIAN_MARKER = 0x4949;
|
|
78
|
+
ThumbnailService.ORIENTATION_TAG = 0x0112;
|
|
79
|
+
ThumbnailService.MARKER_MASK = 0xff00;
|
|
80
|
+
ThumbnailService.NOT_DEFINED = -1;
|
|
81
|
+
ThumbnailService.NOT_JPEG = -2;
|
|
82
|
+
ThumbnailService.INITIAL_OFFSET = 2;
|
|
83
|
+
ThumbnailService.EXIF_OFFSET = 6;
|
|
84
|
+
ThumbnailService.TAG_SIZE = 12;
|
|
85
|
+
ThumbnailService.TAG_VALUE_OFFSET = 8;
|
|
86
|
+
ThumbnailService = ThumbnailService_1 = __decorate([
|
|
87
|
+
Injectable()
|
|
88
|
+
], ThumbnailService);
|
|
89
|
+
export { ThumbnailService };
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thumbnail.service.js","sourceRoot":"ng://@senior-gestao-empresarial/angular-components/","sources":["components/thumbnail/thumbnail.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\n\n@Injectable()\nexport class ThumbnailService {\n    private static readonly HTTP_STATUS_OK = 200;\n    private static readonly JPEG_MARKER = 0xffd8;\n    private static readonly EXIF_MARKER = 0xffe1;\n    private static readonly EXIF_SIGNATURE = 0x45786966;\n    private static readonly LITTLE_ENDIAN_MARKER = 0x4949;\n    private static readonly ORIENTATION_TAG = 0x0112;\n    private static readonly MARKER_MASK = 0xff00;\n    private static readonly NOT_DEFINED = -1;\n    private static readonly NOT_JPEG = -2;\n    private static readonly INITIAL_OFFSET = 2;\n    private static readonly EXIF_OFFSET = 6;\n    private static readonly TAG_SIZE = 12;\n    private static readonly TAG_VALUE_OFFSET = 8;\n\n    public getBinaryFile(img: HTMLImageElement) {\n        return new Promise(resolve => {\n            const getOrientation = this.getOrientation.bind(this);\n\n            let http = new XMLHttpRequest();\n            http.addEventListener(\"load\", () => {\n                if (http.readyState === 4 && (http.status === ThumbnailService.HTTP_STATUS_OK || http.status === 0)) {\n                    const orientation = getOrientation(http.response);\n                    http = null;\n                    resolve(orientation);\n                }\n            });\n\n            http.addEventListener(\"error\", () => {\n                http = null;\n                throw new Error(\"Não foi possível carregar a imagem\");\n            });\n\n            http.open(\"GET\", img.src, true);\n            http.responseType = \"arraybuffer\";\n            http.send(null);\n        });\n    }\n\n    /**\n     * 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.\n     */\n    private getOrientation(file: ArrayBuffer): number {\n        const view = new DataView(file);\n\n        if (view.getUint16(0, false) !== ThumbnailService.JPEG_MARKER) {\n            return ThumbnailService.NOT_JPEG;\n        }\n\n        const length = view.byteLength;\n        let offset = ThumbnailService.INITIAL_OFFSET;\n\n        while (offset < length) {\n            const marker = view.getUint16(offset, false);\n            offset += ThumbnailService.INITIAL_OFFSET;\n\n            if (marker === ThumbnailService.EXIF_MARKER) {\n                const orientation = this.extractOrientationFromExif(view, offset);\n                if (orientation !== null) {\n                    return orientation;\n                }\n                return ThumbnailService.NOT_DEFINED;\n            }\n\n            // tslint:disable-next-line: no-bitwise\n            if ((marker & ThumbnailService.MARKER_MASK) !== ThumbnailService.MARKER_MASK) {\n                break;\n            }\n\n            offset += view.getUint16(offset, false);\n        }\n        return ThumbnailService.NOT_DEFINED;\n    }\n\n    private extractOrientationFromExif(view: DataView, initialOffset: number): number | null {\n        let offset = initialOffset;\n        offset += ThumbnailService.INITIAL_OFFSET;\n\n        if (view.getUint32(offset, false) !== ThumbnailService.EXIF_SIGNATURE) {\n            return null;\n        }\n\n        offset += ThumbnailService.EXIF_OFFSET;\n        const little = view.getUint16(offset, false) === ThumbnailService.LITTLE_ENDIAN_MARKER;\n        offset += view.getUint32(offset + 4, little);\n        const tags = view.getUint16(offset, little);\n        offset += ThumbnailService.INITIAL_OFFSET;\n\n        for (let i = 0; i < tags; i++) {\n            const tagOffset = offset + i * ThumbnailService.TAG_SIZE;\n            if (view.getUint16(tagOffset, little) === ThumbnailService.ORIENTATION_TAG) {\n                return view.getUint16(tagOffset + ThumbnailService.TAG_VALUE_OFFSET, little);\n            }\n        }\n\n        return null;\n    }\n}\n"]}
|
package/esm2015/public-api.js
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
export * from "./components/breadcrumb/index";
|
|
2
2
|
export * from "./components/lookups/index";
|
|
3
|
+
export * from "./components/object-card/index";
|
|
3
4
|
export * from "./components/storage/index";
|
|
5
|
+
export * from "./components/thumbnail/index";
|
|
4
6
|
export * from "./components/polling/index";
|
|
5
7
|
export * from "./components/utils/index";
|
|
6
8
|
export * from "./components/nps/index";
|
|
7
9
|
export * from "./components/websocket/index";
|
|
8
10
|
export * from "./components/permissions/index";
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3ItZ2VzdGFvLWVtcHJlc2FyaWFsL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxnQ0FBZ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2NvbXBvbmVudHMvYnJlYWRjcnVtYi9pbmRleFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29tcG9uZW50cy9sb29rdXBzL2luZGV4XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb21wb25lbnRzL29iamVjdC1jYXJkL2luZGV4XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb21wb25lbnRzL3N0b3JhZ2UvaW5kZXhcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbXBvbmVudHMvdGh1bWJuYWlsL2luZGV4XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb21wb25lbnRzL3BvbGxpbmcvaW5kZXhcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbXBvbmVudHMvdXRpbHMvaW5kZXhcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbXBvbmVudHMvbnBzL2luZGV4XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb21wb25lbnRzL3dlYnNvY2tldC9pbmRleFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29tcG9uZW50cy9wZXJtaXNzaW9ucy9pbmRleFwiO1xuIl19
|
|
@@ -2,10 +2,13 @@
|
|
|
2
2
|
* Generated bundle index. Do not edit.
|
|
3
3
|
*/
|
|
4
4
|
export * from './public-api';
|
|
5
|
-
export { VerifyModulePermissionService as
|
|
6
|
-
export { VerifyModulePermissionsService as
|
|
7
|
-
export {
|
|
8
|
-
export {
|
|
5
|
+
export { VerifyModulePermissionService as ɵh } from './components/permissions/verify-module-permission-service';
|
|
6
|
+
export { VerifyModulePermissionsService as ɵi } from './components/permissions/verify-module-permissions-service';
|
|
7
|
+
export { BorderButtonComponent as ɵe } from './components/shared/border-button/border-button.component';
|
|
8
|
+
export { BorderButtonModule as ɵd } from './components/shared/border-button/border-button.module';
|
|
9
|
+
export { StorageService as ɵf } from './components/storage/storage.service';
|
|
10
|
+
export { ThumbnailService as ɵc } from './components/thumbnail/thumbnail.service';
|
|
11
|
+
export { UserInformationService as ɵg } from './components/websocket/user-information.service';
|
|
9
12
|
export { EnumAnaSin as ɵa } from './core/enums/enum-ana-sin';
|
|
10
13
|
export { EnumNatCtb as ɵb } from './core/enums/enum-nat-ctb';
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC1hbmd1bGFyLWNvbXBvbmVudHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yLWdlc3Rhby1lbXByZXNhcmlhbC9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJzZW5pb3ItZ2VzdGFvLWVtcHJlc2FyaWFsLWFuZ3VsYXItY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyw2QkFBNkIsSUFBSSxFQUFFLEVBQUMsTUFBTSwyREFBMkQsQ0FBQztBQUM5RyxPQUFPLEVBQUMsOEJBQThCLElBQUksRUFBRSxFQUFDLE1BQU0sNERBQTRELENBQUM7QUFDaEgsT0FBTyxFQUFDLHFCQUFxQixJQUFJLEVBQUUsRUFBQyxNQUFNLDJEQUEyRCxDQUFDO0FBQ3RHLE9BQU8sRUFBQyxrQkFBa0IsSUFBSSxFQUFFLEVBQUMsTUFBTSx3REFBd0QsQ0FBQztBQUNoRyxPQUFPLEVBQUMsY0FBYyxJQUFJLEVBQUUsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwwQ0FBMEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsc0JBQXNCLElBQUksRUFBRSxFQUFDLE1BQU0saURBQWlELENBQUM7QUFDN0YsT0FBTyxFQUFDLFVBQVUsSUFBSSxFQUFFLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUMsVUFBVSxJQUFJLEVBQUUsRUFBQyxNQUFNLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuXG5leHBvcnQge1ZlcmlmeU1vZHVsZVBlcm1pc3Npb25TZXJ2aWNlIGFzIMm1aH0gZnJvbSAnLi9jb21wb25lbnRzL3Blcm1pc3Npb25zL3ZlcmlmeS1tb2R1bGUtcGVybWlzc2lvbi1zZXJ2aWNlJztcbmV4cG9ydCB7VmVyaWZ5TW9kdWxlUGVybWlzc2lvbnNTZXJ2aWNlIGFzIMm1aX0gZnJvbSAnLi9jb21wb25lbnRzL3Blcm1pc3Npb25zL3ZlcmlmeS1tb2R1bGUtcGVybWlzc2lvbnMtc2VydmljZSc7XG5leHBvcnQge0JvcmRlckJ1dHRvbkNvbXBvbmVudCBhcyDJtWV9IGZyb20gJy4vY29tcG9uZW50cy9zaGFyZWQvYm9yZGVyLWJ1dHRvbi9ib3JkZXItYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQge0JvcmRlckJ1dHRvbk1vZHVsZSBhcyDJtWR9IGZyb20gJy4vY29tcG9uZW50cy9zaGFyZWQvYm9yZGVyLWJ1dHRvbi9ib3JkZXItYnV0dG9uLm1vZHVsZSc7XG5leHBvcnQge1N0b3JhZ2VTZXJ2aWNlIGFzIMm1Zn0gZnJvbSAnLi9jb21wb25lbnRzL3N0b3JhZ2Uvc3RvcmFnZS5zZXJ2aWNlJztcbmV4cG9ydCB7VGh1bWJuYWlsU2VydmljZSBhcyDJtWN9IGZyb20gJy4vY29tcG9uZW50cy90aHVtYm5haWwvdGh1bWJuYWlsLnNlcnZpY2UnO1xuZXhwb3J0IHtVc2VySW5mb3JtYXRpb25TZXJ2aWNlIGFzIMm1Z30gZnJvbSAnLi9jb21wb25lbnRzL3dlYnNvY2tldC91c2VyLWluZm9ybWF0aW9uLnNlcnZpY2UnO1xuZXhwb3J0IHtFbnVtQW5hU2luIGFzIMm1YX0gZnJvbSAnLi9jb3JlL2VudW1zL2VudW0tYW5hLXNpbic7XG5leHBvcnQge0VudW1OYXRDdGIgYXMgybVifSBmcm9tICcuL2NvcmUvZW51bXMvZW51bS1uYXQtY3RiJzsiXX0=
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, ContentChild, EventEmitter, Input, Output, TemplateRef, ViewChild } from "@angular/core";
|
|
3
|
+
import { ThumbnailComponent } from "../../../thumbnail/thumbnail.component";
|
|
4
|
+
var ObjectCardFieldComponent = /** @class */ (function () {
|
|
5
|
+
function ObjectCardFieldComponent() {
|
|
6
|
+
this.id = "erp-object-card-field-" + ObjectCardFieldComponent_1.getNextId();
|
|
7
|
+
this.buttonClick = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
ObjectCardFieldComponent_1 = ObjectCardFieldComponent;
|
|
10
|
+
ObjectCardFieldComponent.getNextId = function () {
|
|
11
|
+
var id = ObjectCardFieldComponent_1.nextId;
|
|
12
|
+
ObjectCardFieldComponent_1.nextId++;
|
|
13
|
+
return id;
|
|
14
|
+
};
|
|
15
|
+
var ObjectCardFieldComponent_1;
|
|
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
|
+
return ObjectCardFieldComponent;
|
|
58
|
+
}());
|
|
59
|
+
export { ObjectCardFieldComponent };
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LWNhcmQtZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvci1nZXN0YW8tZW1wcmVzYXJpYWwvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9vYmplY3QtY2FyZC9lbGVtZW50cy9maWVsZC9vYmplY3QtY2FyZC1maWVsZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHN0csT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFPNUU7SUFBQTtRQUlXLE9BQUUsR0FBRywyQkFBeUIsMEJBQXdCLENBQUMsU0FBUyxFQUFJLENBQUM7UUF3QnJFLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQWM1QyxDQUFDO2lDQTFDWSx3QkFBd0I7SUFxQ2xCLGtDQUFTLEdBQXhCO1FBQ0ksSUFBTSxFQUFFLEdBQUcsMEJBQXdCLENBQUMsTUFBTSxDQUFDO1FBQzNDLDBCQUF3QixDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2xDLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQzs7SUF4Q2MsK0JBQU0sR0FBRyxDQUFDLENBQUM7SUFHMUI7UUFEQyxLQUFLLEVBQUU7d0RBQ29FO0lBRzVFO1FBREMsS0FBSyxFQUFFO2lFQUNvQjtJQUc1QjtRQURDLEtBQUssRUFBRTs4REFDaUI7SUFHekI7UUFEQyxLQUFLLEVBQUU7K0RBQ2tCO0lBRzFCO1FBREMsS0FBSyxFQUFFOzJEQUNjO0lBR3RCO1FBREMsS0FBSyxFQUFFO2lFQUNvQjtJQUc1QjtRQURDLEtBQUssRUFBRTtpRUFDb0I7SUFHNUI7UUFEQyxLQUFLLEVBQUU7aUVBQ3dCO0lBR2hDO1FBREMsTUFBTSxFQUFFO2lFQUMrQjtJQUd4QztRQURDLFlBQVksQ0FBQyxrQkFBa0IsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQzt3RUFDTDtJQUc5QztRQURDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUM7NkRBQ1I7SUFsQ3hCLHdCQUF3QjtRQUxwQyxTQUFTLENBQUM7WUFDUCxRQUFRLEVBQUUsdUJBQXVCO1lBQ2pDLG10RUFBaUQ7O1NBRXBELENBQUM7T0FDVyx3QkFBd0IsQ0EwQ3BDO0lBQUQsK0JBQUM7Q0FBQSxBQTFDRCxJQTBDQztTQTFDWSx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENvbnRlbnRDaGlsZCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBUZW1wbGF0ZVJlZiwgVmlld0NoaWxkIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1lbnVJdGVtIH0gZnJvbSBcInByaW1lbmcvYXBpXCI7XG5cbmltcG9ydCB7IFRodW1ibmFpbENvbXBvbmVudCB9IGZyb20gXCIuLi8uLi8uLi90aHVtYm5haWwvdGh1bWJuYWlsLmNvbXBvbmVudFwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJlcnAtb2JqZWN0LWNhcmQtZmllbGRcIixcbiAgICB0ZW1wbGF0ZVVybDogXCIuL29iamVjdC1jYXJkLWZpZWxkLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL29iamVjdC1jYXJkLWZpZWxkLmNvbXBvbmVudC5zY3NzXCJdLFxufSlcbmV4cG9ydCBjbGFzcyBPYmplY3RDYXJkRmllbGRDb21wb25lbnQge1xuICAgIHByaXZhdGUgc3RhdGljIG5leHRJZCA9IDA7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpZCA9IGBlcnAtb2JqZWN0LWNhcmQtZmllbGQtJHtPYmplY3RDYXJkRmllbGRDb21wb25lbnQuZ2V0TmV4dElkKCl9YDtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGltYWdlU291cmNlPzogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaW1hZ2VBbHQ/OiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpY29uQ2xhc3M/OiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBsYWJlbD86IHN0cmluZztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgYnV0dG9uTGFiZWw/OiBzdHJpbmc7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBidXR0b25Nb2RlbD86IE1lbnVJdGVtW107XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgYnV0dG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgICBAQ29udGVudENoaWxkKFRodW1ibmFpbENvbXBvbmVudCwgeyBzdGF0aWM6IHRydWUgfSlcbiAgICBwdWJsaWMgdGh1bWJuYWlsQ29tcG9uZW50OiBUaHVtYm5haWxDb21wb25lbnQ7XG5cbiAgICBAVmlld0NoaWxkKFRlbXBsYXRlUmVmLCB7IHN0YXRpYzogdHJ1ZSB9KVxuICAgIHB1YmxpYyBjb250ZW50OiBUZW1wbGF0ZVJlZjxhbnk+O1xuXG5cbiAgICBwcml2YXRlIHN0YXRpYyBnZXROZXh0SWQoKTogbnVtYmVyIHtcbiAgICAgICAgY29uc3QgaWQgPSBPYmplY3RDYXJkRmllbGRDb21wb25lbnQubmV4dElkO1xuICAgICAgICBPYmplY3RDYXJkRmllbGRDb21wb25lbnQubmV4dElkKys7XG4gICAgICAgIHJldHVybiBpZDtcbiAgICB9XG59XG5cblxuIl19
|