lib-portal-angular 0.0.23 → 0.0.28

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,83 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ export class AlertComponent {
5
+ constructor() {
6
+ this.alerts = [];
7
+ this.closeTimeouts = {}; // Armazena os temporizadores para cada alerta
8
+ }
9
+ ngOnInit() {
10
+ // Inicia o temporizador de fechamento para cada alerta quando a página é carregada
11
+ this.alerts.forEach(alert => {
12
+ this.closeTimeouts[alert.message] = setTimeout(() => {
13
+ this.closeAlert(alert);
14
+ }, 6000); // Fecha após 8 segundos
15
+ });
16
+ }
17
+ ngAfterViewInit() {
18
+ // Adiciona a classe 'show' após um curto atraso para acionar a animação
19
+ setTimeout(() => {
20
+ this.alerts.forEach(alert => {
21
+ const element = document.getElementById(`alert-${alert.message}`);
22
+ if (element) {
23
+ element.classList.add('show');
24
+ }
25
+ });
26
+ }, 10); // Pequeno atraso para garantir que o elemento esteja no DOM
27
+ }
28
+ closeAlert(alert) {
29
+ const element = document.getElementById(`alert-${alert.message}`);
30
+ if (element) {
31
+ element.classList.remove('show');
32
+ setTimeout(() => {
33
+ this.alerts = this.alerts.filter(a => a !== alert);
34
+ }, 500); // Duração da animação de saída
35
+ }
36
+ else {
37
+ this.alerts = this.alerts.filter(a => a !== alert);
38
+ }
39
+ }
40
+ getAlertClass(alert) {
41
+ return {
42
+ 'alert-container': true,
43
+ 'alert-dismissible': true,
44
+ [`alert-${alert.type}`]: true
45
+ };
46
+ }
47
+ getAlertIconClass(alert) {
48
+ switch (alert.type) {
49
+ case 'success':
50
+ return 'success-icon'; // Classe para o ícone de sucesso
51
+ case 'info':
52
+ return 'info-icon'; // Classe para o ícone de informação
53
+ case 'warning':
54
+ return 'warning-icon'; // Classe para o ícone de aviso
55
+ case 'danger':
56
+ return 'danger-icon'; // Classe para o ícone de erro
57
+ default:
58
+ return '';
59
+ }
60
+ }
61
+ onMouseEnter(alert) {
62
+ // Cancela o temporizador quando o mouse entra no alerta
63
+ if (this.closeTimeouts[alert.message]) {
64
+ clearTimeout(this.closeTimeouts[alert.message]);
65
+ delete this.closeTimeouts[alert.message];
66
+ }
67
+ }
68
+ onMouseLeave(alert) {
69
+ // Inicia um novo temporizador para fechar o alerta após 2 segundos quando o mouse sai do alerta
70
+ this.closeTimeouts[alert.message] = setTimeout(() => {
71
+ this.closeAlert(alert);
72
+ }, 2000); // Fechar após 2 segundos
73
+ }
74
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AlertComponent, selector: "lib-alert", inputs: { alerts: "alerts" }, ngImport: i0, template: "<div *ngFor=\"let alert of alerts\" \n [ngClass]=\"getAlertClass(alert)\" \n role=\"alert\" \n [id]=\"'alert-' + alert.message\"\n (mouseenter)=\"onMouseEnter(alert)\" \n (mouseleave)=\"onMouseLeave(alert)\">\n <button type=\"button\" class=\"close\" (click)=\"closeAlert(alert)\" aria-label=\"Close\">\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <div class=\"alert-header\">\n <span [ngClass]=\"getAlertIconClass(alert)\" class=\"alert-icon\"></span>\n <strong>{{ alert.title }}</strong>\n </div>\n <div class=\"alert-body\">\n {{ alert.message }}\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.alert-container{position:fixed;top:20px;right:20px;max-width:400px;margin:10px auto;padding:15px;border-radius:4px;background-color:#f8d7da;color:#721c24;word-wrap:break-word;opacity:0;transform:translateY(-20px);transition:opacity .5s ease,transform .5s ease;display:flex;flex-direction:column;align-items:flex-start}.alert-container.show{opacity:1;transform:translateY(0)}.alert-container .close{position:absolute;top:10px;right:10px;background:none;border:none;font-size:20px;color:#000;opacity:.5;cursor:pointer;outline:none}.alert-container .close:hover{opacity:1}.alert-container .alert-header{display:flex;align-items:center;margin-bottom:5px}.alert-container .alert-icon{margin-right:10px;font-size:20px}.alert-container .alert-body{margin-left:30px}.alert-container .alert-icon.success-icon:before{content:\"\\2714\\fe0f\"}.alert-container .alert-icon.info-icon:before{content:\"\\2139\\fe0f\"}.alert-container .alert-icon.warning-icon:before{content:\"\\26a0\\fe0f\"}.alert-container .alert-icon.danger-icon:before{content:\"\\274c\"}.alert-success{background-color:#d4edda;color:#155724}.alert-info{background-color:#d8f4f7;color:#0c5460}.alert-warning{background-color:#fff3cd;color:#856404}.alert-danger{background-color:#fdd9d7;color:#721c24}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
76
+ }
77
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AlertComponent, decorators: [{
78
+ type: Component,
79
+ args: [{ selector: 'lib-alert', template: "<div *ngFor=\"let alert of alerts\" \n [ngClass]=\"getAlertClass(alert)\" \n role=\"alert\" \n [id]=\"'alert-' + alert.message\"\n (mouseenter)=\"onMouseEnter(alert)\" \n (mouseleave)=\"onMouseLeave(alert)\">\n <button type=\"button\" class=\"close\" (click)=\"closeAlert(alert)\" aria-label=\"Close\">\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <div class=\"alert-header\">\n <span [ngClass]=\"getAlertIconClass(alert)\" class=\"alert-icon\"></span>\n <strong>{{ alert.title }}</strong>\n </div>\n <div class=\"alert-body\">\n {{ alert.message }}\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.alert-container{position:fixed;top:20px;right:20px;max-width:400px;margin:10px auto;padding:15px;border-radius:4px;background-color:#f8d7da;color:#721c24;word-wrap:break-word;opacity:0;transform:translateY(-20px);transition:opacity .5s ease,transform .5s ease;display:flex;flex-direction:column;align-items:flex-start}.alert-container.show{opacity:1;transform:translateY(0)}.alert-container .close{position:absolute;top:10px;right:10px;background:none;border:none;font-size:20px;color:#000;opacity:.5;cursor:pointer;outline:none}.alert-container .close:hover{opacity:1}.alert-container .alert-header{display:flex;align-items:center;margin-bottom:5px}.alert-container .alert-icon{margin-right:10px;font-size:20px}.alert-container .alert-body{margin-left:30px}.alert-container .alert-icon.success-icon:before{content:\"\\2714\\fe0f\"}.alert-container .alert-icon.info-icon:before{content:\"\\2139\\fe0f\"}.alert-container .alert-icon.warning-icon:before{content:\"\\26a0\\fe0f\"}.alert-container .alert-icon.danger-icon:before{content:\"\\274c\"}.alert-success{background-color:#d4edda;color:#155724}.alert-info{background-color:#d8f4f7;color:#0c5460}.alert-warning{background-color:#fff3cd;color:#856404}.alert-danger{background-color:#fdd9d7;color:#721c24}\n"] }]
80
+ }], propDecorators: { alerts: [{
81
+ type: Input
82
+ }] } });
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/alert/alert.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/alert/alert.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Input, OnInit } from '@angular/core';\nimport { Alert } from './notification.service';\n\n@Component({\n    selector: 'lib-alert',\n    templateUrl: './alert.component.html',\n    styleUrls: ['./alert.component.scss']\n})\nexport class AlertComponent implements OnInit, AfterViewInit {\n    @Input() alerts: Alert[] = [];\n    private closeTimeouts: { [key: string]: any } = {}; // Armazena os temporizadores para cada alerta\n\n    ngOnInit(): void {\n        // Inicia o temporizador de fechamento para cada alerta quando a página é carregada\n        this.alerts.forEach(alert => {\n            this.closeTimeouts[alert.message] = setTimeout(() => {\n                this.closeAlert(alert);\n            }, 6000); // Fecha após 8 segundos\n        });\n    }\n\n    ngAfterViewInit(): void {\n        // Adiciona a classe 'show' após um curto atraso para acionar a animação\n        setTimeout(() => {\n            this.alerts.forEach(alert => {\n                const element = document.getElementById(`alert-${alert.message}`);\n                if (element) {\n                    element.classList.add('show');\n                }\n            });\n        }, 10); // Pequeno atraso para garantir que o elemento esteja no DOM\n    }\n\n    closeAlert(alert: Alert) {\n        const element = document.getElementById(`alert-${alert.message}`);\n        if (element) {\n            element.classList.remove('show');\n            setTimeout(() => {\n                this.alerts = this.alerts.filter(a => a !== alert);\n            }, 500); // Duração da animação de saída\n        } else {\n            this.alerts = this.alerts.filter(a => a !== alert);\n        }\n    }\n\n    getAlertClass(alert: Alert) {\n        return {\n            'alert-container': true,\n            'alert-dismissible': true,\n            [`alert-${alert.type}`]: true\n        };\n    }\n\n    getAlertIconClass(alert: Alert) {\n        switch (alert.type) {\n            case 'success':\n                return 'success-icon'; // Classe para o ícone de sucesso\n            case 'info':\n                return 'info-icon'; // Classe para o ícone de informação\n            case 'warning':\n                return 'warning-icon'; // Classe para o ícone de aviso\n            case 'danger':\n                return 'danger-icon'; // Classe para o ícone de erro\n            default:\n                return '';\n        }\n    }\n\n    onMouseEnter(alert: Alert) {\n        // Cancela o temporizador quando o mouse entra no alerta\n        if (this.closeTimeouts[alert.message]) {\n            clearTimeout(this.closeTimeouts[alert.message]);\n            delete this.closeTimeouts[alert.message];\n        }\n    }\n\n    onMouseLeave(alert: Alert) {\n        // Inicia um novo temporizador para fechar o alerta após 2 segundos quando o mouse sai do alerta\n        this.closeTimeouts[alert.message] = setTimeout(() => {\n            this.closeAlert(alert);\n        }, 2000); // Fechar após 2 segundos\n    }\n}\n","<div *ngFor=\"let alert of alerts\" \n     [ngClass]=\"getAlertClass(alert)\" \n     role=\"alert\" \n     [id]=\"'alert-' + alert.message\"\n     (mouseenter)=\"onMouseEnter(alert)\" \n     (mouseleave)=\"onMouseLeave(alert)\">\n  <button type=\"button\" class=\"close\" (click)=\"closeAlert(alert)\" aria-label=\"Close\">\n    <span aria-hidden=\"true\">&times;</span>\n  </button>\n  <div class=\"alert-header\">\n    <span [ngClass]=\"getAlertIconClass(alert)\" class=\"alert-icon\"></span>\n    <strong>{{ alert.title }}</strong>\n  </div>\n  <div class=\"alert-body\">\n    {{ alert.message }}\n  </div>\n</div>\n"]}
@@ -0,0 +1,31 @@
1
+ import { createComponent, Injectable } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { AlertComponent } from './alert.component';
4
+ import * as i0 from "@angular/core";
5
+ export class NotificationService {
6
+ constructor(appRef, injector) {
7
+ this.appRef = appRef;
8
+ this.injector = injector;
9
+ this.alertsSubject = new Subject();
10
+ this.alerts$ = this.alertsSubject.asObservable();
11
+ }
12
+ showAlert(type, title, message) {
13
+ const alert = { type, title, message };
14
+ this.alertsSubject.next(alert);
15
+ // Create the alert component dynamically
16
+ const componentRef = createComponent(AlertComponent, { environmentInjector: this.appRef.injector });
17
+ componentRef.instance.alerts = [alert];
18
+ this.appRef.attachView(componentRef.hostView);
19
+ const domElem = componentRef.hostView.rootNodes[0];
20
+ document.body.appendChild(domElem);
21
+ }
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationService, deps: [{ token: i0.ApplicationRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
23
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationService, providedIn: 'root' }); }
24
+ }
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NotificationService, decorators: [{
26
+ type: Injectable,
27
+ args: [{
28
+ providedIn: 'root'
29
+ }]
30
+ }], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.Injector }]; } });
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2FsZXJ0L25vdGlmaWNhdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBZ0MsZUFBZSxFQUFFLFVBQVUsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUNwRyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9CLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFXbkQsTUFBTSxPQUFPLG1CQUFtQjtJQUk1QixZQUNZLE1BQXNCLEVBQ3RCLFFBQWtCO1FBRGxCLFdBQU0sR0FBTixNQUFNLENBQWdCO1FBQ3RCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFMdEIsa0JBQWEsR0FBRyxJQUFJLE9BQU8sRUFBUyxDQUFDO1FBQzdDLFlBQU8sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBS3hDLENBQUM7SUFFTCxTQUFTLENBQUMsSUFBK0MsRUFBRSxLQUFhLEVBQUUsT0FBZTtRQUNyRixNQUFNLEtBQUssR0FBVSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLENBQUM7UUFDOUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFL0IseUNBQXlDO1FBQ3pDLE1BQU0sWUFBWSxHQUFpQyxlQUFlLENBQUMsY0FBYyxFQUFFLEVBQUUsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ2xJLFlBQVksQ0FBQyxRQUFRLENBQUMsTUFBTSxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFdkMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzlDLE1BQU0sT0FBTyxHQUFJLFlBQVksQ0FBQyxRQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQWdCLENBQUM7UUFDM0UsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7SUFHdkMsQ0FBQzsrR0F0QlEsbUJBQW1CO21IQUFuQixtQkFBbUIsY0FGaEIsTUFBTTs7NEZBRVQsbUJBQW1CO2tCQUgvQixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRSZWYsIGNyZWF0ZUNvbXBvbmVudCwgSW5qZWN0YWJsZSwgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEFsZXJ0Q29tcG9uZW50IH0gZnJvbSAnLi9hbGVydC5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFsZXJ0IHtcbiAgICB0eXBlOiAnc3VjY2VzcycgfCAnaW5mbycgfCAnd2FybmluZycgfCAnZGFuZ2VyJztcbiAgICB0aXRsZTogc3RyaW5nO1xuICAgIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBOb3RpZmljYXRpb25TZXJ2aWNlIHtcbiAgICBwcml2YXRlIGFsZXJ0c1N1YmplY3QgPSBuZXcgU3ViamVjdDxBbGVydD4oKTtcbiAgICBhbGVydHMkID0gdGhpcy5hbGVydHNTdWJqZWN0LmFzT2JzZXJ2YWJsZSgpO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgYXBwUmVmOiBBcHBsaWNhdGlvblJlZixcbiAgICAgICAgcHJpdmF0ZSBpbmplY3RvcjogSW5qZWN0b3JcbiAgICApIHsgfVxuXG4gICAgc2hvd0FsZXJ0KHR5cGU6ICdzdWNjZXNzJyB8ICdpbmZvJyB8ICd3YXJuaW5nJyB8ICdkYW5nZXInLCB0aXRsZTogc3RyaW5nLCBtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICAgICAgY29uc3QgYWxlcnQ6IEFsZXJ0ID0geyB0eXBlLCB0aXRsZSwgbWVzc2FnZSB9O1xuICAgICAgICB0aGlzLmFsZXJ0c1N1YmplY3QubmV4dChhbGVydCk7XG5cbiAgICAgICAgLy8gQ3JlYXRlIHRoZSBhbGVydCBjb21wb25lbnQgZHluYW1pY2FsbHlcbiAgICAgICAgY29uc3QgY29tcG9uZW50UmVmOiBDb21wb25lbnRSZWY8QWxlcnRDb21wb25lbnQ+ID0gY3JlYXRlQ29tcG9uZW50KEFsZXJ0Q29tcG9uZW50LCB7IGVudmlyb25tZW50SW5qZWN0b3I6IHRoaXMuYXBwUmVmLmluamVjdG9yIH0pO1xuICAgICAgICBjb21wb25lbnRSZWYuaW5zdGFuY2UuYWxlcnRzID0gW2FsZXJ0XTtcblxuICAgICAgICB0aGlzLmFwcFJlZi5hdHRhY2hWaWV3KGNvbXBvbmVudFJlZi5ob3N0Vmlldyk7XG4gICAgICAgIGNvbnN0IGRvbUVsZW0gPSAoY29tcG9uZW50UmVmLmhvc3RWaWV3IGFzIGFueSkucm9vdE5vZGVzWzBdIGFzIEhUTUxFbGVtZW50O1xuICAgICAgICBkb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKGRvbUVsZW0pO1xuICAgICAgICBcbiAgICAgICAgXG4gICAgfVxufVxuIl19
@@ -22,6 +22,8 @@ export class ButtonComponent {
22
22
  this.marginBottom = 0;
23
23
  this.marginLeft = 0;
24
24
  this.marginRight = 0;
25
+ this.permissions = [];
26
+ this.permissionChecker = null;
25
27
  this.clickEvent = new EventEmitter();
26
28
  this.isHovered = false;
27
29
  this.isActive = false;
@@ -96,47 +98,57 @@ export class ButtonComponent {
96
98
  'filter': activeFilter
97
99
  };
98
100
  }
101
+ hasPermission() {
102
+ if (!this.permissionChecker || this.permissions.length === 0) {
103
+ return true;
104
+ }
105
+ return this.permissionChecker(this.permissions);
106
+ }
99
107
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
100
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "sim-app-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight" }, outputs: { clickEvent: "clickEvent" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()" } }, ngImport: i0, template: `
101
- <button [type]="type"
102
- class="btn"
103
- [ngClass]="btnClass"
104
- [ngStyle]="getDynamicStyles()"
105
- (click)="onClick($event)"
106
- [disabled]="disabled"
107
- [attr.autofocus]="autofocus ? true : null"
108
- [attr.form]="form"
109
- [attr.formaction]="formaction"
110
- [attr.formenctype]="formenctype"
111
- [attr.formmethod]="formmethod"
112
- [attr.formnovalidate]="formnovalidate"
113
- [attr.formtarget]="formtarget"
114
- [attr.name]="name"
115
- [attr.value]="value">
116
- {{ label }}
117
- </button>
118
- `, isInline: true, styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:Inter,sans-serif;font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
108
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "sim-app-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", permissions: "permissions", permissionChecker: "permissionChecker" }, outputs: { clickEvent: "clickEvent" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()" } }, ngImport: i0, template: `
109
+ <ng-container *ngIf="hasPermission()">
110
+ <button [type]="type"
111
+ class="btn"
112
+ [ngClass]="btnClass"
113
+ [ngStyle]="getDynamicStyles()"
114
+ (click)="onClick($event)"
115
+ [disabled]="disabled"
116
+ [attr.autofocus]="autofocus ? true : null"
117
+ [attr.form]="form"
118
+ [attr.formaction]="formaction"
119
+ [attr.formenctype]="formenctype"
120
+ [attr.formmethod]="formmethod"
121
+ [attr.formnovalidate]="formnovalidate"
122
+ [attr.formtarget]="formtarget"
123
+ [attr.name]="name"
124
+ [attr.value]="value">
125
+ {{ label }}
126
+ </button>
127
+ </ng-container>
128
+ `, isInline: true, styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:Inter,sans-serif;font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
119
129
  }
120
130
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, decorators: [{
121
131
  type: Component,
122
132
  args: [{ selector: 'sim-app-button', template: `
123
- <button [type]="type"
124
- class="btn"
125
- [ngClass]="btnClass"
126
- [ngStyle]="getDynamicStyles()"
127
- (click)="onClick($event)"
128
- [disabled]="disabled"
129
- [attr.autofocus]="autofocus ? true : null"
130
- [attr.form]="form"
131
- [attr.formaction]="formaction"
132
- [attr.formenctype]="formenctype"
133
- [attr.formmethod]="formmethod"
134
- [attr.formnovalidate]="formnovalidate"
135
- [attr.formtarget]="formtarget"
136
- [attr.name]="name"
137
- [attr.value]="value">
138
- {{ label }}
139
- </button>
133
+ <ng-container *ngIf="hasPermission()">
134
+ <button [type]="type"
135
+ class="btn"
136
+ [ngClass]="btnClass"
137
+ [ngStyle]="getDynamicStyles()"
138
+ (click)="onClick($event)"
139
+ [disabled]="disabled"
140
+ [attr.autofocus]="autofocus ? true : null"
141
+ [attr.form]="form"
142
+ [attr.formaction]="formaction"
143
+ [attr.formenctype]="formenctype"
144
+ [attr.formmethod]="formmethod"
145
+ [attr.formnovalidate]="formnovalidate"
146
+ [attr.formtarget]="formtarget"
147
+ [attr.name]="name"
148
+ [attr.value]="value">
149
+ {{ label }}
150
+ </button>
151
+ </ng-container>
140
152
  `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:Inter,sans-serif;font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left}\n"] }]
141
153
  }], propDecorators: { type: [{
142
154
  type: Input
@@ -174,6 +186,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
174
186
  type: Input
175
187
  }], marginRight: [{
176
188
  type: Input
189
+ }], permissions: [{
190
+ type: Input
191
+ }], permissionChecker: [{
192
+ type: Input
177
193
  }], clickEvent: [{
178
194
  type: Output
179
195
  }], onMouseEnter: [{
@@ -189,4 +205,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
189
205
  type: HostListener,
190
206
  args: ['mouseup']
191
207
  }] } });
192
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\nimport { ButtonClasses } from '../../enum/ButtonClassesEnum';\n\n@Component({\n  selector: 'sim-app-button',\n  template: `\n    <button [type]=\"type\"\n            class=\"btn\"\n            [ngClass]=\"btnClass\"\n            [ngStyle]=\"getDynamicStyles()\"\n            (click)=\"onClick($event)\"\n            [disabled]=\"disabled\"\n            [attr.autofocus]=\"autofocus ? true : null\"\n            [attr.form]=\"form\"\n            [attr.formaction]=\"formaction\"\n            [attr.formenctype]=\"formenctype\"\n            [attr.formmethod]=\"formmethod\"\n            [attr.formnovalidate]=\"formnovalidate\"\n            [attr.formtarget]=\"formtarget\"\n            [attr.name]=\"name\"\n            [attr.value]=\"value\">\n      {{ label }}\n    </button>\n  `,\n  styles: [`\n    .btn {\n      padding: 0.5rem 1rem;\n      border-radius: 0.25rem;\n      transition: background-color 0.3s, border-color 0.3s, filter 0.3s;\n      font-family: 'Inter', sans-serif;\n      font-size: 16px;\n      font-weight: 600;\n      line-height: 24px;\n      letter-spacing: 0.005em;\n      text-align: left;\n    }\n  `],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ButtonComponent {\n  @Input() type: string = 'button';\n  @Input() label: string = 'Submit';\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Input() fontSize: string = '1rem';\n  @Input() disabled: boolean = false;\n  @Input() autofocus: boolean = false;\n  @Input() form: string | null = null;\n  @Input() formaction: string | null = null;\n  @Input() formenctype: string | null = null;\n  @Input() formmethod: string | null = null;\n  @Input() formnovalidate: boolean = false;\n  @Input() formtarget: string | null = null;\n  @Input() name: string | null = null;\n  @Input() value: string | null = null;\n\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n\n  @Output() clickEvent: EventEmitter<Event> = new EventEmitter<Event>();\n\n  private isHovered: boolean = false;\n  private isActive: boolean = false;\n\n  @HostListener('mouseenter') onMouseEnter() {\n    this.isHovered = true;\n  }\n\n  @HostListener('mouseleave') onMouseLeave() {\n    this.isHovered = false;\n    this.isActive = false;\n  }\n\n  @HostListener('mousedown') onMouseDown() {\n    this.isActive = true;\n  }\n\n  @HostListener('mouseup') onMouseUp() {\n    this.isActive = false;\n  }\n\n  onClick(event: Event) {\n    this.clickEvent.emit(event);\n  }\n\n  getDynamicStyles() {\n    let backgroundColor = '';\n    let textColor = '#fff'; // Default text color\n    let borderColor = '';\n\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        backgroundColor = '#00444C';\n        break;\n      case ButtonClasses.Secondary:\n        backgroundColor = '#2CA58D';\n        break;\n      case ButtonClasses.Success:\n        backgroundColor = '#00C853';\n        break;\n      case ButtonClasses.Danger:\n        backgroundColor = '#D32F2F';\n        break;\n      case ButtonClasses.Warning:\n        backgroundColor = '#FFC107';\n        break;\n      case ButtonClasses.Info:\n        backgroundColor = '#3EC9D6';\n        break;\n      case ButtonClasses.Light:\n        backgroundColor = '#EEF2F6';\n        textColor = '#00444C'; // Custom text color for Light\n        break;\n      case ButtonClasses.Dark:\n        backgroundColor = '#111936';\n        break;\n      case ButtonClasses.Link:\n        backgroundColor = 'transparent';\n        borderColor = '#DDE5E9';\n        textColor = '#00444C'; // Custom text color for Link\n        break;\n      default:\n        backgroundColor = '#00444C';\n        break;\n    }\n\n    const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness\n    const activeFilter = this.isActive ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness\n\n    return {\n      'font-size': this.fontSize,\n      'margin-top': `${this.marginTop}rem`,\n      'margin-bottom': `${this.marginBottom}rem`,\n      'margin-left': `${this.marginLeft}rem`,\n      'margin-right': `${this.marginRight}rem`,\n      'background-color': backgroundColor,\n      'color': textColor,\n      'border': borderColor ? `1px solid ${borderColor}` : 'none',\n      'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',\n      'filter': activeFilter\n    };\n  }\n}\n"]}
208
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\nimport { ButtonClasses } from '../../enum/ButtonClassesEnum';\n\n@Component({\n  selector: 'sim-app-button',\n  template: `\n    <ng-container *ngIf=\"hasPermission()\">\n      <button [type]=\"type\"\n              class=\"btn\"\n              [ngClass]=\"btnClass\"\n              [ngStyle]=\"getDynamicStyles()\"\n              (click)=\"onClick($event)\"\n              [disabled]=\"disabled\"\n              [attr.autofocus]=\"autofocus ? true : null\"\n              [attr.form]=\"form\"\n              [attr.formaction]=\"formaction\"\n              [attr.formenctype]=\"formenctype\"\n              [attr.formmethod]=\"formmethod\"\n              [attr.formnovalidate]=\"formnovalidate\"\n              [attr.formtarget]=\"formtarget\"\n              [attr.name]=\"name\"\n              [attr.value]=\"value\">\n        {{ label }}\n      </button>\n    </ng-container>\n  `,\n  styles: [`\n    .btn {\n      padding: 0.5rem 1rem;\n      border-radius: 0.25rem;\n      transition: background-color 0.3s, border-color 0.3s, filter 0.3s;\n      font-family: 'Inter', sans-serif;\n      font-size: 16px;\n      font-weight: 600;\n      line-height: 24px;\n      letter-spacing: 0.005em;\n      text-align: left;\n    }\n  `],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ButtonComponent {\n  @Input() type: string = 'button';\n  @Input() label: string = 'Submit';\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Input() fontSize: string = '1rem';\n  @Input() disabled: boolean = false;\n  @Input() autofocus: boolean = false;\n  @Input() form: string | null = null;\n  @Input() formaction: string | null = null;\n  @Input() formenctype: string | null = null;\n  @Input() formmethod: string | null = null;\n  @Input() formnovalidate: boolean = false;\n  @Input() formtarget: string | null = null;\n  @Input() name: string | null = null;\n  @Input() value: string | null = null;\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n\n  @Input() permissions: string[] = [];\n  @Input() permissionChecker: ((permissions: string[]) => boolean) | null = null;\n\n  @Output() clickEvent: EventEmitter<Event> = new EventEmitter<Event>();\n\n  private isHovered: boolean = false;\n  private isActive: boolean = false;\n\n  @HostListener('mouseenter') onMouseEnter() {\n    this.isHovered = true;\n  }\n\n  @HostListener('mouseleave') onMouseLeave() {\n    this.isHovered = false;\n    this.isActive = false;\n  }\n\n  @HostListener('mousedown') onMouseDown() {\n    this.isActive = true;\n  }\n\n  @HostListener('mouseup') onMouseUp() {\n    this.isActive = false;\n  }\n\n  onClick(event: Event) {\n    this.clickEvent.emit(event);\n  }\n\n  getDynamicStyles() {\n    let backgroundColor = '';\n    let textColor = '#fff'; // Default text color\n    let borderColor = '';\n\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        backgroundColor = '#00444C';\n        break;\n      case ButtonClasses.Secondary:\n        backgroundColor = '#2CA58D';\n        break;\n      case ButtonClasses.Success:\n        backgroundColor = '#00C853';\n        break;\n      case ButtonClasses.Danger:\n        backgroundColor = '#D32F2F';\n        break;\n      case ButtonClasses.Warning:\n        backgroundColor = '#FFC107';\n        break;\n      case ButtonClasses.Info:\n        backgroundColor = '#3EC9D6';\n        break;\n      case ButtonClasses.Light:\n        backgroundColor = '#EEF2F6';\n        textColor = '#00444C'; // Custom text color for Light\n        break;\n      case ButtonClasses.Dark:\n        backgroundColor = '#111936';\n        break;\n      case ButtonClasses.Link:\n        backgroundColor = 'transparent';\n        borderColor = '#DDE5E9';\n        textColor = '#00444C'; // Custom text color for Link\n        break;\n      default:\n        backgroundColor = '#00444C';\n        break;\n    }\n\n    const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness\n    const activeFilter = this.isActive ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness\n\n    return {\n      'font-size': this.fontSize,\n      'margin-top': `${this.marginTop}rem`,\n      'margin-bottom': `${this.marginBottom}rem`,\n      'margin-left': `${this.marginLeft}rem`,\n      'margin-right': `${this.marginRight}rem`,\n      'background-color': backgroundColor,\n      'color': textColor,\n      'border': borderColor ? `1px solid ${borderColor}` : 'none',\n      'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',\n      'filter': activeFilter\n    };\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissionChecker || this.permissions.length === 0) {\n      return true;\n    }\n    return this.permissionChecker(this.permissions);\n  }\n}\n"]}
@@ -2,11 +2,8 @@ import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
3
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  import { NgSelectModule } from '@ng-select/ng-select';
5
- import { FlatpickrModule } from 'angularx-flatpickr';
6
5
  import { NgxPaginationModule } from 'ngx-pagination';
7
- import { CalendarComponent } from './advanced-calendar/calendar.component';
8
- import { DatePickerComponent } from './advanced-calendar/date-picker.component';
9
- import { DateTimePickerComponent } from './advanced-calendar/date-time-picker.component';
6
+ import { AlertComponent } from './alert/alert.component';
10
7
  import { BadgeComponent } from './badge/badge.component';
11
8
  import { ButtonComponent } from './button/button.component';
12
9
  import { CardComponent } from './card/card.component';
@@ -20,7 +17,6 @@ import { SelectComponent } from './select/select.component';
20
17
  import { BootstrapTableComponent } from './tables/bootstrap-table.component';
21
18
  import { TextareaComponent } from './textarea/textarea.component';
22
19
  import * as i0 from "@angular/core";
23
- import * as i1 from "angularx-flatpickr";
24
20
  export class ComponentsModule {
25
21
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
26
22
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, declarations: [ButtonComponent,
@@ -32,15 +28,14 @@ export class ComponentsModule {
32
28
  SelectComponent,
33
29
  RadioComponent,
34
30
  MultiSelectComponent,
35
- CalendarComponent,
36
- DatePickerComponent,
37
- DateTimePickerComponent,
38
31
  BootstrapTableComponent,
39
32
  CodeHighlightComponent,
40
- BadgeComponent], imports: [CommonModule,
33
+ BadgeComponent,
34
+ AlertComponent], imports: [CommonModule,
41
35
  FormsModule,
42
36
  ReactiveFormsModule,
43
- NgSelectModule, i1.FlatpickrModule, NgxPaginationModule], exports: [ButtonComponent,
37
+ NgSelectModule,
38
+ NgxPaginationModule], exports: [ButtonComponent,
44
39
  CardComponent,
45
40
  FormComponent,
46
41
  InputComponent,
@@ -52,17 +47,14 @@ export class ComponentsModule {
52
47
  FormsModule,
53
48
  ReactiveFormsModule,
54
49
  NgSelectModule,
55
- CalendarComponent,
56
- DatePickerComponent,
57
- DateTimePickerComponent,
58
50
  BootstrapTableComponent,
59
51
  CodeHighlightComponent,
60
- BadgeComponent] }); }
52
+ BadgeComponent,
53
+ AlertComponent] }); }
61
54
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, imports: [CommonModule,
62
55
  FormsModule,
63
56
  ReactiveFormsModule,
64
57
  NgSelectModule,
65
- FlatpickrModule.forRoot(),
66
58
  NgxPaginationModule, FormsModule,
67
59
  ReactiveFormsModule,
68
60
  NgSelectModule] }); }
@@ -80,20 +72,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
80
72
  SelectComponent,
81
73
  RadioComponent,
82
74
  MultiSelectComponent,
83
- CalendarComponent,
84
- DatePickerComponent,
85
- DateTimePickerComponent,
86
75
  BootstrapTableComponent,
87
76
  CodeHighlightComponent,
88
- BadgeComponent
77
+ BadgeComponent,
78
+ AlertComponent,
89
79
  ],
90
80
  imports: [
91
81
  CommonModule,
92
82
  FormsModule,
93
83
  ReactiveFormsModule,
94
84
  NgSelectModule,
95
- FlatpickrModule.forRoot(),
96
- NgxPaginationModule
85
+ NgxPaginationModule,
97
86
  ],
98
87
  exports: [
99
88
  ButtonComponent,
@@ -108,13 +97,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
108
97
  FormsModule,
109
98
  ReactiveFormsModule,
110
99
  NgSelectModule,
111
- CalendarComponent,
112
- DatePickerComponent,
113
- DateTimePickerComponent,
114
100
  BootstrapTableComponent,
115
101
  CodeHighlightComponent,
116
- BadgeComponent
117
- ]
102
+ BadgeComponent,
103
+ AlertComponent,
104
+ ],
118
105
  }]
119
106
  }] });
120
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2NvbXBvbmVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3pGLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM3RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7O0FBaURsRSxNQUFNLE9BQU8sZ0JBQWdCOytHQUFoQixnQkFBZ0I7Z0hBQWhCLGdCQUFnQixpQkE3Q3pCLGVBQWU7WUFDZixhQUFhO1lBQ2IsYUFBYTtZQUNiLGNBQWM7WUFDZCxpQkFBaUI7WUFDakIsaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZixjQUFjO1lBQ2Qsb0JBQW9CO1lBQ3BCLGlCQUFpQjtZQUNqQixtQkFBbUI7WUFDbkIsdUJBQXVCO1lBQ3ZCLHVCQUF1QjtZQUN2QixzQkFBc0I7WUFDdEIsY0FBYyxhQUdkLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWMsc0JBRWQsbUJBQW1CLGFBR25CLGVBQWU7WUFDZixhQUFhO1lBQ2IsYUFBYTtZQUNiLGNBQWM7WUFDZCxpQkFBaUI7WUFDakIsaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZixjQUFjO1lBQ2Qsb0JBQW9CO1lBQ3BCLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLGlCQUFpQjtZQUNqQixtQkFBbUI7WUFDbkIsdUJBQXVCO1lBQ3ZCLHVCQUF1QjtZQUN2QixzQkFBc0I7WUFDdEIsY0FBYztnSEFHTCxnQkFBZ0IsWUE1QnpCLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCxlQUFlLENBQUMsT0FBTyxFQUFFO1lBQ3pCLG1CQUFtQixFQVluQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWM7OzRGQVNMLGdCQUFnQjtrQkEvQzVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixhQUFhO3dCQUNiLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixpQkFBaUI7d0JBQ2pCLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxvQkFBb0I7d0JBQ3BCLGlCQUFpQjt3QkFDakIsbUJBQW1CO3dCQUNuQix1QkFBdUI7d0JBQ3ZCLHVCQUF1Qjt3QkFDdkIsc0JBQXNCO3dCQUN0QixjQUFjO3FCQUNmO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixjQUFjO3dCQUNkLGVBQWUsQ0FBQyxPQUFPLEVBQUU7d0JBQ3pCLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixhQUFhO3dCQUNiLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixpQkFBaUI7d0JBQ2pCLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxvQkFBb0I7d0JBQ3BCLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsbUJBQW1CO3dCQUNuQix1QkFBdUI7d0JBQ3ZCLHVCQUF1Qjt3QkFDdkIsc0JBQXNCO3dCQUN0QixjQUFjO3FCQUNmO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE5nU2VsZWN0TW9kdWxlIH0gZnJvbSAnQG5nLXNlbGVjdC9uZy1zZWxlY3QnO1xuaW1wb3J0IHsgRmxhdHBpY2tyTW9kdWxlIH0gZnJvbSAnYW5ndWxhcngtZmxhdHBpY2tyJztcbmltcG9ydCB7IE5neFBhZ2luYXRpb25Nb2R1bGUgfSBmcm9tICduZ3gtcGFnaW5hdGlvbic7XG5pbXBvcnQgeyBDYWxlbmRhckNvbXBvbmVudCB9IGZyb20gJy4vYWR2YW5jZWQtY2FsZW5kYXIvY2FsZW5kYXIuY29tcG9uZW50JztcbmltcG9ydCB7IERhdGVQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2FkdmFuY2VkLWNhbGVuZGFyL2RhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRlVGltZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vYWR2YW5jZWQtY2FsZW5kYXIvZGF0ZS10aW1lLXBpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmFkZ2VDb21wb25lbnQgfSBmcm9tICcuL2JhZGdlL2JhZGdlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IENhcmRDb21wb25lbnQgfSBmcm9tICcuL2NhcmQvY2FyZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2hlY2tib3hDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb2RlSGlnaGxpZ2h0Q29tcG9uZW50IH0gZnJvbSAnLi9jb2RlLWhpZ2hsaWdodC9jb2RlLWhpZ2hsaWdodC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9ybUNvbXBvbmVudCB9IGZyb20gJy4vZm9ybS9mb3JtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vaW1wdXQvaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IE11bHRpU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9tdWx0aS1zZWxlY3QvbXVsdGktc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSYWRpb0NvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8vcmFkaW8uY29tcG9uZW50JztcbmltcG9ydCB7IFNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0L3NlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQm9vdHN0cmFwVGFibGVDb21wb25lbnQgfSBmcm9tICcuL3RhYmxlcy9ib290c3RyYXAtdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRleHRhcmVhQ29tcG9uZW50IH0gZnJvbSAnLi90ZXh0YXJlYS90ZXh0YXJlYS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBCdXR0b25Db21wb25lbnQsXG4gICAgQ2FyZENvbXBvbmVudCxcbiAgICBGb3JtQ29tcG9uZW50LFxuICAgIElucHV0Q29tcG9uZW50LFxuICAgIENoZWNrYm94Q29tcG9uZW50LFxuICAgIFRleHRhcmVhQ29tcG9uZW50LFxuICAgIFNlbGVjdENvbXBvbmVudCxcbiAgICBSYWRpb0NvbXBvbmVudCxcbiAgICBNdWx0aVNlbGVjdENvbXBvbmVudCxcbiAgICBDYWxlbmRhckNvbXBvbmVudCxcbiAgICBEYXRlUGlja2VyQ29tcG9uZW50LFxuICAgIERhdGVUaW1lUGlja2VyQ29tcG9uZW50LFxuICAgIEJvb3RzdHJhcFRhYmxlQ29tcG9uZW50LFxuICAgIENvZGVIaWdobGlnaHRDb21wb25lbnQsXG4gICAgQmFkZ2VDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIE5nU2VsZWN0TW9kdWxlLFxuICAgIEZsYXRwaWNrck1vZHVsZS5mb3JSb290KCksXG4gICAgTmd4UGFnaW5hdGlvbk1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgQnV0dG9uQ29tcG9uZW50LFxuICAgIENhcmRDb21wb25lbnQsXG4gICAgRm9ybUNvbXBvbmVudCxcbiAgICBJbnB1dENvbXBvbmVudCxcbiAgICBDaGVja2JveENvbXBvbmVudCxcbiAgICBUZXh0YXJlYUNvbXBvbmVudCxcbiAgICBTZWxlY3RDb21wb25lbnQsXG4gICAgUmFkaW9Db21wb25lbnQsXG4gICAgTXVsdGlTZWxlY3RDb21wb25lbnQsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBOZ1NlbGVjdE1vZHVsZSxcbiAgICBDYWxlbmRhckNvbXBvbmVudCxcbiAgICBEYXRlUGlja2VyQ29tcG9uZW50LFxuICAgIERhdGVUaW1lUGlja2VyQ29tcG9uZW50LFxuICAgIEJvb3RzdHJhcFRhYmxlQ29tcG9uZW50LFxuICAgIENvZGVIaWdobGlnaHRDb21wb25lbnQsXG4gICAgQmFkZ2VDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBDb21wb25lbnRzTW9kdWxlIHsgfVxuIl19
107
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2NvbXBvbmVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM3RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7QUE0Q2xFLE1BQU0sT0FBTyxnQkFBZ0I7K0dBQWhCLGdCQUFnQjtnSEFBaEIsZ0JBQWdCLGlCQXhDekIsZUFBZTtZQUNmLGFBQWE7WUFDYixhQUFhO1lBQ2IsY0FBYztZQUNkLGlCQUFpQjtZQUNqQixpQkFBaUI7WUFDakIsZUFBZTtZQUNmLGNBQWM7WUFDZCxvQkFBb0I7WUFDcEIsdUJBQXVCO1lBQ3ZCLHNCQUFzQjtZQUN0QixjQUFjO1lBQ2QsY0FBYyxhQUdkLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCxtQkFBbUIsYUFHbkIsZUFBZTtZQUNmLGFBQWE7WUFDYixhQUFhO1lBQ2IsY0FBYztZQUNkLGlCQUFpQjtZQUNqQixpQkFBaUI7WUFDakIsZUFBZTtZQUNmLGNBQWM7WUFDZCxvQkFBb0I7WUFDcEIsV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsdUJBQXVCO1lBQ3ZCLHNCQUFzQjtZQUN0QixjQUFjO1lBQ2QsY0FBYztnSEFHTCxnQkFBZ0IsWUF6QnpCLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCxtQkFBbUIsRUFZbkIsV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjOzs0RkFPTCxnQkFBZ0I7a0JBMUM1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsaUJBQWlCO3dCQUNqQixlQUFlO3dCQUNmLGNBQWM7d0JBQ2Qsb0JBQW9CO3dCQUNwQix1QkFBdUI7d0JBQ3ZCLHNCQUFzQjt3QkFDdEIsY0FBYzt3QkFDZCxjQUFjO3FCQUNmO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixjQUFjO3dCQUNkLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixhQUFhO3dCQUNiLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixpQkFBaUI7d0JBQ2pCLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxvQkFBb0I7d0JBQ3BCLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixjQUFjO3dCQUNkLHVCQUF1Qjt3QkFDdkIsc0JBQXNCO3dCQUN0QixjQUFjO3dCQUNkLGNBQWM7cUJBQ2Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTmdTZWxlY3RNb2R1bGUgfSBmcm9tICdAbmctc2VsZWN0L25nLXNlbGVjdCc7XG5pbXBvcnQgeyBOZ3hQYWdpbmF0aW9uTW9kdWxlIH0gZnJvbSAnbmd4LXBhZ2luYXRpb24nO1xuaW1wb3J0IHsgQWxlcnRDb21wb25lbnQgfSBmcm9tICcuL2FsZXJ0L2FsZXJ0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCYWRnZUNvbXBvbmVudCB9IGZyb20gJy4vYmFkZ2UvYmFkZ2UuY29tcG9uZW50JztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2FyZENvbXBvbmVudCB9IGZyb20gJy4vY2FyZC9jYXJkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDaGVja2JveENvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmltcG9ydCB7IENvZGVIaWdobGlnaHRDb21wb25lbnQgfSBmcm9tICcuL2NvZGUtaGlnaGxpZ2h0L2NvZGUtaGlnaGxpZ2h0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9mb3JtL2Zvcm0uY29tcG9uZW50JztcbmltcG9ydCB7IElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9pbXB1dC9pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTXVsdGlTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL211bHRpLXNlbGVjdC9tdWx0aS1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IFJhZGlvQ29tcG9uZW50IH0gZnJvbSAnLi9yYWRpby9yYWRpby5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCb290c3RyYXBUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vdGFibGVzL2Jvb3RzdHJhcC10YWJsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGV4dGFyZWFDb21wb25lbnQgfSBmcm9tICcuL3RleHRhcmVhL3RleHRhcmVhLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEJ1dHRvbkNvbXBvbmVudCxcbiAgICBDYXJkQ29tcG9uZW50LFxuICAgIEZvcm1Db21wb25lbnQsXG4gICAgSW5wdXRDb21wb25lbnQsXG4gICAgQ2hlY2tib3hDb21wb25lbnQsXG4gICAgVGV4dGFyZWFDb21wb25lbnQsXG4gICAgU2VsZWN0Q29tcG9uZW50LFxuICAgIFJhZGlvQ29tcG9uZW50LFxuICAgIE11bHRpU2VsZWN0Q29tcG9uZW50LFxuICAgIEJvb3RzdHJhcFRhYmxlQ29tcG9uZW50LFxuICAgIENvZGVIaWdobGlnaHRDb21wb25lbnQsXG4gICAgQmFkZ2VDb21wb25lbnQsXG4gICAgQWxlcnRDb21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBOZ1NlbGVjdE1vZHVsZSxcbiAgICBOZ3hQYWdpbmF0aW9uTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgQnV0dG9uQ29tcG9uZW50LFxuICAgIENhcmRDb21wb25lbnQsXG4gICAgRm9ybUNvbXBvbmVudCxcbiAgICBJbnB1dENvbXBvbmVudCxcbiAgICBDaGVja2JveENvbXBvbmVudCxcbiAgICBUZXh0YXJlYUNvbXBvbmVudCxcbiAgICBTZWxlY3RDb21wb25lbnQsXG4gICAgUmFkaW9Db21wb25lbnQsXG4gICAgTXVsdGlTZWxlY3RDb21wb25lbnQsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBOZ1NlbGVjdE1vZHVsZSxcbiAgICBCb290c3RyYXBUYWJsZUNvbXBvbmVudCxcbiAgICBDb2RlSGlnaGxpZ2h0Q29tcG9uZW50LFxuICAgIEJhZGdlQ29tcG9uZW50LFxuICAgIEFsZXJ0Q29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDb21wb25lbnRzTW9kdWxlIHsgfVxuIl19
@@ -1,36 +1,63 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../card/card.component";
3
+ import * as i1 from "@angular/common";
4
4
  export class FormComponent {
5
5
  constructor() {
6
6
  this.cardTitle = 'Default Form Title';
7
+ this.colClasses = 'col-12'; // Classes de coluna responsiva
8
+ // Valores de margem dinâmica
9
+ this.marginTop = 0; // Em rem
10
+ this.marginLeft = 0; // Em rem
11
+ this.marginRight = 0; // Em rem
12
+ }
13
+ getRowStyles() {
14
+ return {
15
+ 'margin-top': `${this.marginTop}rem`,
16
+ 'margin-left': `${this.marginLeft}rem`,
17
+ 'margin-right': `${this.marginRight}rem`
18
+ };
7
19
  }
8
20
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormComponent, selector: "sim-app-form", inputs: { cardTitle: "cardTitle" }, ngImport: i0, template: `
10
- <div class="row mt-2 mx-1">
11
- <div class="col-sm-12">
12
- <sim-app-card [cardTitle]="cardTitle">
13
- <ng-content></ng-content>
14
- </sim-app-card>
21
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormComponent, selector: "sim-app-form", inputs: { cardTitle: "cardTitle", colClasses: "colClasses", marginTop: "marginTop", marginLeft: "marginLeft", marginRight: "marginRight" }, ngImport: i0, template: `
22
+ <div class="row" [ngStyle]="getRowStyles()">
23
+ <div [ngClass]="colClasses">
24
+ <div class="card">
25
+ <div class="card-title">
26
+ {{ cardTitle }}
27
+ </div>
28
+ <div class="card-content">
29
+ <ng-content></ng-content>
30
+ </div>
31
+ </div>
15
32
  </div>
16
33
  </div>
17
- `, isInline: true, dependencies: [{ kind: "component", type: i1.CardComponent, selector: "sim-app-card", inputs: ["cardTitle"] }] }); }
34
+ `, isInline: true, styles: [".row{margin-top:.5rem;margin-left:.25rem;margin-right:.25rem}.col-12{padding:0}.card{border:1px solid #ddd;border-radius:.25rem;padding:1rem}.card-title{font-family:Inter,sans-serif;font-size:42px;font-weight:700;line-height:50.83px;text-align:left;width:98%;height:51px;gap:0px;opacity:0px;margin-bottom:1rem}.card-content{font-family:Arial,sans-serif}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
18
35
  }
19
36
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormComponent, decorators: [{
20
37
  type: Component,
21
- args: [{
22
- selector: 'sim-app-form',
23
- template: `
24
- <div class="row mt-2 mx-1">
25
- <div class="col-sm-12">
26
- <sim-app-card [cardTitle]="cardTitle">
27
- <ng-content></ng-content>
28
- </sim-app-card>
38
+ args: [{ selector: 'sim-app-form', template: `
39
+ <div class="row" [ngStyle]="getRowStyles()">
40
+ <div [ngClass]="colClasses">
41
+ <div class="card">
42
+ <div class="card-title">
43
+ {{ cardTitle }}
44
+ </div>
45
+ <div class="card-content">
46
+ <ng-content></ng-content>
47
+ </div>
48
+ </div>
29
49
  </div>
30
50
  </div>
31
- `
32
- }]
51
+ `, styles: [".row{margin-top:.5rem;margin-left:.25rem;margin-right:.25rem}.col-12{padding:0}.card{border:1px solid #ddd;border-radius:.25rem;padding:1rem}.card-title{font-family:Inter,sans-serif;font-size:42px;font-weight:700;line-height:50.83px;text-align:left;width:98%;height:51px;gap:0px;opacity:0px;margin-bottom:1rem}.card-content{font-family:Arial,sans-serif}\n"] }]
33
52
  }], propDecorators: { cardTitle: [{
34
53
  type: Input
54
+ }], colClasses: [{
55
+ type: Input
56
+ }], marginTop: [{
57
+ type: Input
58
+ }], marginLeft: [{
59
+ type: Input
60
+ }], marginRight: [{
61
+ type: Input
35
62
  }] } });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vZm9ybS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWNqRCxNQUFNLE9BQU8sYUFBYTtJQVoxQjtRQWFXLGNBQVMsR0FBVyxvQkFBb0IsQ0FBQztLQUNuRDsrR0FGWSxhQUFhO21HQUFiLGFBQWEsd0ZBVmQ7Ozs7Ozs7O0dBUVQ7OzRGQUVVLGFBQWE7a0JBWnpCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFFBQVEsRUFBRTs7Ozs7Ozs7R0FRVDtpQkFDRjs4QkFFVSxTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzaW0tYXBwLWZvcm0nLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJyb3cgbXQtMiBteC0xXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLXNtLTEyXCI+XG4gICAgICAgIDxzaW0tYXBwLWNhcmQgW2NhcmRUaXRsZV09XCJjYXJkVGl0bGVcIj5cbiAgICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICAgIDwvc2ltLWFwcC1jYXJkPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIGBcbn0pXG5leHBvcnQgY2xhc3MgRm9ybUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGNhcmRUaXRsZTogc3RyaW5nID0gJ0RlZmF1bHQgRm9ybSBUaXRsZSc7XG59XG4iXX0=
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vZm9ybS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWlEakQsTUFBTSxPQUFPLGFBQWE7SUEvQzFCO1FBZ0RXLGNBQVMsR0FBVyxvQkFBb0IsQ0FBQztRQUN6QyxlQUFVLEdBQVcsUUFBUSxDQUFDLENBQUMsK0JBQStCO1FBRXZFLDZCQUE2QjtRQUNwQixjQUFTLEdBQVcsQ0FBQyxDQUFDLENBQUMsU0FBUztRQUNoQyxlQUFVLEdBQVcsQ0FBQyxDQUFDLENBQUMsU0FBUztRQUNqQyxnQkFBVyxHQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVM7S0FTNUM7SUFQQyxZQUFZO1FBQ1YsT0FBTztZQUNMLFlBQVksRUFBRSxHQUFHLElBQUksQ0FBQyxTQUFTLEtBQUs7WUFDcEMsYUFBYSxFQUFFLEdBQUcsSUFBSSxDQUFDLFVBQVUsS0FBSztZQUN0QyxjQUFjLEVBQUUsR0FBRyxJQUFJLENBQUMsV0FBVyxLQUFLO1NBQ3pDLENBQUM7SUFDSixDQUFDOytHQWZVLGFBQWE7bUdBQWIsYUFBYSxnTUE3Q2Q7Ozs7Ozs7Ozs7Ozs7R0FhVDs7NEZBZ0NVLGFBQWE7a0JBL0N6QixTQUFTOytCQUNFLGNBQWMsWUFDZDs7Ozs7Ozs7Ozs7OztHQWFUOzhCQWlDUSxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBR0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NpbS1hcHAtZm9ybScsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cInJvd1wiIFtuZ1N0eWxlXT1cImdldFJvd1N0eWxlcygpXCI+XG4gICAgICA8ZGl2IFtuZ0NsYXNzXT1cImNvbENsYXNzZXNcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNhcmRcIj5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwiY2FyZC10aXRsZVwiPlxuICAgICAgICAgICAge3sgY2FyZFRpdGxlIH19XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImNhcmQtY29udGVudFwiPlxuICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtgXG4gICAgLnJvdyB7XG4gICAgICBtYXJnaW4tdG9wOiAwLjVyZW07XG4gICAgICBtYXJnaW4tbGVmdDogMC4yNXJlbTtcbiAgICAgIG1hcmdpbi1yaWdodDogMC4yNXJlbTtcbiAgICB9XG4gICAgLmNvbC0xMiB7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cbiAgICAuY2FyZCB7XG4gICAgICBib3JkZXI6IDFweCBzb2xpZCAjZGRkO1xuICAgICAgYm9yZGVyLXJhZGl1czogMC4yNXJlbTtcbiAgICAgIHBhZGRpbmc6IDFyZW07XG4gICAgfVxuICAgIC5jYXJkLXRpdGxlIHtcbiAgICAgIGZvbnQtZmFtaWx5OiBJbnRlciwgc2Fucy1zZXJpZjtcbiAgICAgIGZvbnQtc2l6ZTogNDJweDtcbiAgICAgIGZvbnQtd2VpZ2h0OiA3MDA7XG4gICAgICBsaW5lLWhlaWdodDogNTAuODNweDtcbiAgICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gICAgICB3aWR0aDogOTglO1xuICAgICAgaGVpZ2h0OiA1MXB4O1xuICAgICAgZ2FwOiAwcHg7XG4gICAgICBvcGFjaXR5OiAwcHg7XG4gICAgICBtYXJnaW4tYm90dG9tOiAxcmVtO1xuICAgIH1cbiAgICAuY2FyZC1jb250ZW50IHtcbiAgICAgIGZvbnQtZmFtaWx5OiBBcmlhbCwgc2Fucy1zZXJpZjtcbiAgICB9XG4gIGBdXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1Db21wb25lbnQge1xuICBASW5wdXQoKSBjYXJkVGl0bGU6IHN0cmluZyA9ICdEZWZhdWx0IEZvcm0gVGl0bGUnO1xuICBASW5wdXQoKSBjb2xDbGFzc2VzOiBzdHJpbmcgPSAnY29sLTEyJzsgLy8gQ2xhc3NlcyBkZSBjb2x1bmEgcmVzcG9uc2l2YVxuXG4gIC8vIFZhbG9yZXMgZGUgbWFyZ2VtIGRpbsOibWljYVxuICBASW5wdXQoKSBtYXJnaW5Ub3A6IG51bWJlciA9IDA7IC8vIEVtIHJlbVxuICBASW5wdXQoKSBtYXJnaW5MZWZ0OiBudW1iZXIgPSAwOyAvLyBFbSByZW1cbiAgQElucHV0KCkgbWFyZ2luUmlnaHQ6IG51bWJlciA9IDA7IC8vIEVtIHJlbVxuXG4gIGdldFJvd1N0eWxlcygpIHtcbiAgICByZXR1cm4ge1xuICAgICAgJ21hcmdpbi10b3AnOiBgJHt0aGlzLm1hcmdpblRvcH1yZW1gLFxuICAgICAgJ21hcmdpbi1sZWZ0JzogYCR7dGhpcy5tYXJnaW5MZWZ0fXJlbWAsXG4gICAgICAnbWFyZ2luLXJpZ2h0JzogYCR7dGhpcy5tYXJnaW5SaWdodH1yZW1gXG4gICAgfTtcbiAgfVxufVxuIl19