lib-portal-angular 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +24 -0
- package/esm2022/lib/components/advanced-calendar/calendar.component.mjs +135 -0
- package/esm2022/lib/components/advanced-calendar/date-picker.component.mjs +113 -0
- package/esm2022/lib/components/advanced-calendar/date-time-picker.component.mjs +113 -0
- package/esm2022/lib/components/badge/badge.component.mjs +151 -0
- package/esm2022/lib/components/button/button.component.mjs +192 -0
- package/esm2022/lib/components/card/card.component.mjs +37 -0
- package/esm2022/lib/components/checkbox/checkbox.component.mjs +112 -0
- package/esm2022/lib/components/code-highlight/code-highlight.component.mjs +51 -0
- package/esm2022/lib/components/components.module.mjs +120 -0
- package/esm2022/lib/components/form/form.component.mjs +36 -0
- package/esm2022/lib/components/imput/input.component.mjs +189 -0
- package/esm2022/lib/components/multi-select/multi-select.component.mjs +147 -0
- package/esm2022/lib/components/radio/radio.component.mjs +114 -0
- package/esm2022/lib/components/select/select.component.mjs +107 -0
- package/esm2022/lib/components/tables/bootstrap-table.component.mjs +115 -0
- package/esm2022/lib/components/textarea/textarea.component.mjs +184 -0
- package/esm2022/lib/enum/ButtonClassesEnum.mjs +13 -0
- package/esm2022/lib/lib-portal-angular.module.mjs +20 -0
- package/esm2022/lib-portal-angular.mjs +5 -0
- package/esm2022/public-api.mjs +28 -0
- package/fesm2022/lib-portal-angular.mjs +1887 -0
- package/fesm2022/lib-portal-angular.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/advanced-calendar/calendar.component.d.ts +28 -0
- package/lib/components/advanced-calendar/date-picker.component.d.ts +25 -0
- package/lib/components/advanced-calendar/date-time-picker.component.d.ts +25 -0
- package/lib/components/badge/badge.component.d.ts +34 -0
- package/lib/components/button/button.component.d.ts +45 -0
- package/lib/components/card/card.component.d.ts +6 -0
- package/lib/components/checkbox/checkbox.component.d.ts +23 -0
- package/lib/components/code-highlight/code-highlight.component.d.ts +15 -0
- package/lib/components/components.module.d.ts +26 -0
- package/lib/components/form/form.component.d.ts +6 -0
- package/lib/components/imput/input.component.d.ts +43 -0
- package/lib/components/multi-select/multi-select.component.d.ts +31 -0
- package/lib/components/radio/radio.component.d.ts +25 -0
- package/lib/components/select/select.component.d.ts +27 -0
- package/lib/components/tables/bootstrap-table.component.d.ts +33 -0
- package/lib/components/textarea/textarea.component.d.ts +42 -0
- package/lib/enum/ButtonClassesEnum.d.ts +11 -0
- package/lib/lib-portal-angular.module.d.ts +7 -0
- package/package.json +25 -0
- package/public-api.d.ts +18 -0
@@ -0,0 +1,115 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
import * as i1 from "@angular/common";
|
4
|
+
import * as i2 from "@angular/forms";
|
5
|
+
import * as i3 from "ngx-pagination";
|
6
|
+
export class BootstrapTableComponent {
|
7
|
+
constructor() {
|
8
|
+
this.columns = [];
|
9
|
+
this.data = [];
|
10
|
+
this.itemsPerPageOptions = [5, 10, 15, 20];
|
11
|
+
this.defaultItemsPerPage = 10;
|
12
|
+
this.marginTop = 0;
|
13
|
+
this.marginBottom = 0;
|
14
|
+
this.marginLeft = 0;
|
15
|
+
this.marginRight = 0;
|
16
|
+
this.showActionColumn = false;
|
17
|
+
this.actionColumnLabel = 'Actions';
|
18
|
+
this.sortChange = new EventEmitter();
|
19
|
+
this.pageChange = new EventEmitter();
|
20
|
+
this.itemsPerPageChange = new EventEmitter();
|
21
|
+
this.onEditTable = new EventEmitter();
|
22
|
+
this.onDeleteTable = new EventEmitter();
|
23
|
+
this.onViewTable = new EventEmitter();
|
24
|
+
this.currentPage = 1;
|
25
|
+
this.totalItems = 0;
|
26
|
+
this.config = {
|
27
|
+
id: 'bootstrap-table',
|
28
|
+
itemsPerPage: this.defaultItemsPerPage,
|
29
|
+
currentPage: this.currentPage,
|
30
|
+
totalItems: this.totalItems
|
31
|
+
};
|
32
|
+
}
|
33
|
+
ngOnInit() {
|
34
|
+
this.totalItems = this.data.length;
|
35
|
+
this.updateConfig();
|
36
|
+
}
|
37
|
+
ngOnChanges(changes) {
|
38
|
+
if (changes['data']) {
|
39
|
+
this.totalItems = this.data.length;
|
40
|
+
this.updateConfig();
|
41
|
+
}
|
42
|
+
}
|
43
|
+
updateConfig() {
|
44
|
+
this.config.itemsPerPage = this.defaultItemsPerPage;
|
45
|
+
this.config.currentPage = this.currentPage;
|
46
|
+
this.config.totalItems = this.totalItems;
|
47
|
+
}
|
48
|
+
onSort(column) {
|
49
|
+
this.sortChange.emit(column);
|
50
|
+
}
|
51
|
+
onPageChange(page) {
|
52
|
+
this.currentPage = page;
|
53
|
+
this.config.currentPage = page;
|
54
|
+
this.pageChange.emit(page);
|
55
|
+
}
|
56
|
+
onItemsPerPageChange(event) {
|
57
|
+
const itemsPerPage = parseInt(event, 10);
|
58
|
+
this.defaultItemsPerPage = itemsPerPage;
|
59
|
+
this.config.itemsPerPage = itemsPerPage;
|
60
|
+
this.itemsPerPageChange.emit(itemsPerPage);
|
61
|
+
this.updateConfig();
|
62
|
+
}
|
63
|
+
handleAction(action, item, index) {
|
64
|
+
switch (action) {
|
65
|
+
case 'edit':
|
66
|
+
this.onEditTable.emit({ item, index });
|
67
|
+
break;
|
68
|
+
case 'delete':
|
69
|
+
this.onDeleteTable.emit({ item, index });
|
70
|
+
break;
|
71
|
+
case 'view':
|
72
|
+
this.onViewTable.emit({ item, index });
|
73
|
+
break;
|
74
|
+
}
|
75
|
+
}
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BootstrapTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BootstrapTableComponent, selector: "sim-bootstrap-table", inputs: { columns: "columns", data: "data", itemsPerPageOptions: "itemsPerPageOptions", defaultItemsPerPage: "defaultItemsPerPage", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", showActionColumn: "showActionColumn", actionColumnLabel: "actionColumnLabel" }, outputs: { sortChange: "sortChange", pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onViewTable: "onViewTable" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\" [ngStyle]=\"{\n 'margin-top': marginTop + 'rem',\n 'margin-bottom': marginBottom + 'rem',\n 'margin-left': marginLeft + 'rem',\n 'margin-right': marginRight + 'rem'\n}\" style=\"text-align: right;\">\n <label for=\"itemsPerPageSelect\" style=\"margin-right: 0.5rem; margin-bottom: 0.7rem;\">Itens por P\u00E1gina:</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange($event)\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n</div>\n\n<div class=\"table-responsive\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <th *ngFor=\"let column of columns\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n <th *ngIf=\"showActionColumn\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of data | paginate: config; let i = index\">\n <td *ngFor=\"let column of columns\">\n {{ item[column.prop] }}\n </td>\n <td *ngIf=\"showActionColumn\">\n <div class=\"d-flex justify-content-center\">\n <button *ngIf=\"onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"btn btn-sm btn-primary mx-1\">Edit</button>\n <button *ngIf=\"onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"btn btn-sm btn-danger mx-1\">Delete</button>\n <button *ngIf=\"onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"btn btn-sm btn-info mx-1\">View</button>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center\">\n <pagination-controls id=\"bootstrap-table\" (pageChange)=\"onPageChange($event)\" previousLabel=\"Anterior\" nextLabel=\"Pr\u00F3ximo\" [responsive]=\"true\"></pagination-controls>\n</div>\n\n\n<!-- Estilos CSS diretamente no HTML -->\n<style>\n .table thead th {\n background-color: #343a40; /* Tom de cinza escuro */\n color: #fff;\n }\n</style>\n", styles: ["", "\n .table thead th {\n background-color: #343a40; /* Tom de cinza escuro */\n color: #fff;\n }\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PaginationControlsComponent, selector: "pagination-controls", inputs: ["id", "maxSize", "directionLinks", "autoHide", "responsive", "previousLabel", "nextLabel", "screenReaderPaginationLabel", "screenReaderPageLabel", "screenReaderCurrentLabel"], outputs: ["pageChange", "pageBoundsCorrection"] }, { kind: "pipe", type: i3.PaginatePipe, name: "paginate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
78
|
+
}
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BootstrapTableComponent, decorators: [{
|
80
|
+
type: Component,
|
81
|
+
args: [{ selector: 'sim-bootstrap-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"form-group\" [ngStyle]=\"{\n 'margin-top': marginTop + 'rem',\n 'margin-bottom': marginBottom + 'rem',\n 'margin-left': marginLeft + 'rem',\n 'margin-right': marginRight + 'rem'\n}\" style=\"text-align: right;\">\n <label for=\"itemsPerPageSelect\" style=\"margin-right: 0.5rem; margin-bottom: 0.7rem;\">Itens por P\u00E1gina:</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange($event)\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n</div>\n\n<div class=\"table-responsive\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <th *ngFor=\"let column of columns\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n <th *ngIf=\"showActionColumn\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of data | paginate: config; let i = index\">\n <td *ngFor=\"let column of columns\">\n {{ item[column.prop] }}\n </td>\n <td *ngIf=\"showActionColumn\">\n <div class=\"d-flex justify-content-center\">\n <button *ngIf=\"onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"btn btn-sm btn-primary mx-1\">Edit</button>\n <button *ngIf=\"onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"btn btn-sm btn-danger mx-1\">Delete</button>\n <button *ngIf=\"onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"btn btn-sm btn-info mx-1\">View</button>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center\">\n <pagination-controls id=\"bootstrap-table\" (pageChange)=\"onPageChange($event)\" previousLabel=\"Anterior\" nextLabel=\"Pr\u00F3ximo\" [responsive]=\"true\"></pagination-controls>\n</div>\n\n\n<!-- Estilos CSS diretamente no HTML -->\n<style>\n .table thead th {\n background-color: #343a40; /* Tom de cinza escuro */\n color: #fff;\n }\n</style>\n", styles: ["\n .table thead th {\n background-color: #343a40; /* Tom de cinza escuro */\n color: #fff;\n }\n"] }]
|
82
|
+
}], propDecorators: { columns: [{
|
83
|
+
type: Input
|
84
|
+
}], data: [{
|
85
|
+
type: Input
|
86
|
+
}], itemsPerPageOptions: [{
|
87
|
+
type: Input
|
88
|
+
}], defaultItemsPerPage: [{
|
89
|
+
type: Input
|
90
|
+
}], marginTop: [{
|
91
|
+
type: Input
|
92
|
+
}], marginBottom: [{
|
93
|
+
type: Input
|
94
|
+
}], marginLeft: [{
|
95
|
+
type: Input
|
96
|
+
}], marginRight: [{
|
97
|
+
type: Input
|
98
|
+
}], showActionColumn: [{
|
99
|
+
type: Input
|
100
|
+
}], actionColumnLabel: [{
|
101
|
+
type: Input
|
102
|
+
}], sortChange: [{
|
103
|
+
type: Output
|
104
|
+
}], pageChange: [{
|
105
|
+
type: Output
|
106
|
+
}], itemsPerPageChange: [{
|
107
|
+
type: Output
|
108
|
+
}], onEditTable: [{
|
109
|
+
type: Output
|
110
|
+
}], onDeleteTable: [{
|
111
|
+
type: Output
|
112
|
+
}], onViewTable: [{
|
113
|
+
type: Output
|
114
|
+
}] } });
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bootstrap-table.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/tables/bootstrap-table.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/tables/bootstrap-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { PaginationInstance } from 'ngx-pagination';\n\n@Component({\n  selector: 'sim-bootstrap-table',\n  templateUrl: './bootstrap-table.component.html',\n  styleUrls: ['./bootstrap-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BootstrapTableComponent implements OnInit, OnChanges {\n  @Input() columns: any[] = [];\n  @Input() data: any[] = [];\n  @Input() itemsPerPageOptions: number[] = [5, 10, 15, 20];\n  @Input() defaultItemsPerPage: number = 10;\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n  @Input() showActionColumn: boolean = false;\n  @Input() actionColumnLabel: string = 'Actions';\n\n  @Output() sortChange: EventEmitter<any> = new EventEmitter();\n  @Output() pageChange: EventEmitter<number> = new EventEmitter();\n  @Output() itemsPerPageChange: EventEmitter<number> = new EventEmitter();\n  @Output() onEditTable: EventEmitter<any> = new EventEmitter();\n  @Output() onDeleteTable: EventEmitter<any> = new EventEmitter();\n  @Output() onViewTable: EventEmitter<any> = new EventEmitter();\n\n  currentPage: number = 1;\n  totalItems: number = 0;\n  config: PaginationInstance = {\n    id: 'bootstrap-table',\n    itemsPerPage: this.defaultItemsPerPage,\n    currentPage: this.currentPage,\n    totalItems: this.totalItems\n  };\n\n  ngOnInit() {\n    this.totalItems = this.data.length;\n    this.updateConfig();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['data']) {\n      this.totalItems = this.data.length;\n      this.updateConfig();\n    }\n  }\n\n  updateConfig() {\n    this.config.itemsPerPage = this.defaultItemsPerPage;\n    this.config.currentPage = this.currentPage;\n    this.config.totalItems = this.totalItems;\n  }\n\n  onSort(column: string) {\n    this.sortChange.emit(column);\n  }\n\n  onPageChange(page: number) {\n    this.currentPage = page;\n    this.config.currentPage = page;\n    this.pageChange.emit(page);\n  }\n\n  onItemsPerPageChange(event: any) {\n    const itemsPerPage = parseInt(event, 10);\n    this.defaultItemsPerPage = itemsPerPage;\n    this.config.itemsPerPage = itemsPerPage;\n    this.itemsPerPageChange.emit(itemsPerPage);\n    this.updateConfig();\n  }\n\n  handleAction(action: string, item: any, index: number) {\n    switch (action) {\n      case 'edit':\n        this.onEditTable.emit({ item, index });\n        break;\n      case 'delete':\n        this.onDeleteTable.emit({ item, index });\n        break;\n      case 'view':\n        this.onViewTable.emit({ item, index });\n        break;\n    }\n  }\n}\n","<div class=\"form-group\" [ngStyle]=\"{\n  'margin-top': marginTop + 'rem',\n  'margin-bottom': marginBottom + 'rem',\n  'margin-left': marginLeft + 'rem',\n  'margin-right': marginRight + 'rem'\n}\" style=\"text-align: right;\">\n  <label for=\"itemsPerPageSelect\" style=\"margin-right: 0.5rem; margin-bottom: 0.7rem;\">Itens por Página:</label>\n  <select\n    id=\"itemsPerPageSelect\"\n    class=\"form-control form-control-sm d-inline-block w-auto\"\n    [(ngModel)]=\"defaultItemsPerPage\"\n    (ngModelChange)=\"onItemsPerPageChange($event)\">\n    <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n  </select>\n</div>\n\n<div class=\"table-responsive\">\n  <table class=\"table table-hover\">\n    <thead>\n      <tr>\n        <th *ngFor=\"let column of columns\" (click)=\"onSort(column.prop)\">\n          {{ column.label }}\n        </th>\n        <th *ngIf=\"showActionColumn\">{{ actionColumnLabel }}</th>\n      </tr>\n    </thead>\n    <tbody>\n      <tr *ngFor=\"let item of data | paginate: config; let i = index\">\n        <td *ngFor=\"let column of columns\">\n          {{ item[column.prop] }}\n        </td>\n        <td *ngIf=\"showActionColumn\">\n          <div class=\"d-flex justify-content-center\">\n            <button *ngIf=\"onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"btn btn-sm btn-primary mx-1\">Edit</button>\n            <button *ngIf=\"onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"btn btn-sm btn-danger mx-1\">Delete</button>\n            <button *ngIf=\"onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"btn btn-sm btn-info mx-1\">View</button>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>\n</div>\n\n<div class=\"text-center\">\n  <pagination-controls id=\"bootstrap-table\" (pageChange)=\"onPageChange($event)\" previousLabel=\"Anterior\" nextLabel=\"Próximo\" [responsive]=\"true\"></pagination-controls>\n</div>\n\n\n<!-- Estilos CSS diretamente no HTML -->\n<style>\n  .table thead th {\n    background-color: #343a40; /* Tom de cinza escuro */\n    color: #fff;\n  }\n</style>\n"]}
|
@@ -0,0 +1,184 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, forwardRef } from '@angular/core';
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@angular/common";
|
5
|
+
export class TextareaComponent {
|
6
|
+
constructor() {
|
7
|
+
this.label = 'Default Label';
|
8
|
+
this.placeholder = 'Default Placeholder';
|
9
|
+
this.id = 'textareaId';
|
10
|
+
this.rows = 3;
|
11
|
+
this.disabled = false;
|
12
|
+
this.readonly = false;
|
13
|
+
this.maxlength = null;
|
14
|
+
this.minlength = null;
|
15
|
+
this.required = false;
|
16
|
+
this.autofocus = false;
|
17
|
+
this.marginTop = 0;
|
18
|
+
this.marginBottom = 0;
|
19
|
+
this.marginLeft = 0;
|
20
|
+
this.marginRight = 0;
|
21
|
+
this.inputEvent = new EventEmitter();
|
22
|
+
this.changeEvent = new EventEmitter();
|
23
|
+
this.focusEvent = new EventEmitter();
|
24
|
+
this.blurEvent = new EventEmitter();
|
25
|
+
this.keyupEvent = new EventEmitter();
|
26
|
+
this.keydownEvent = new EventEmitter();
|
27
|
+
this.keypressEvent = new EventEmitter();
|
28
|
+
this.onChangeCallback = () => { };
|
29
|
+
this.onTouchedCallback = () => { };
|
30
|
+
this.value = '';
|
31
|
+
}
|
32
|
+
onInput(event) {
|
33
|
+
const inputElement = event.target;
|
34
|
+
this.value = inputElement.value;
|
35
|
+
this.onChangeCallback(this.value);
|
36
|
+
this.inputEvent.emit(event);
|
37
|
+
}
|
38
|
+
onChange(event) {
|
39
|
+
this.changeEvent.emit(event);
|
40
|
+
}
|
41
|
+
onFocus(event) {
|
42
|
+
this.focusEvent.emit(event);
|
43
|
+
}
|
44
|
+
onBlur(event) {
|
45
|
+
this.onTouchedCallback();
|
46
|
+
this.blurEvent.emit(event);
|
47
|
+
}
|
48
|
+
onKeyup(event) {
|
49
|
+
this.keyupEvent.emit(event);
|
50
|
+
}
|
51
|
+
onKeydown(event) {
|
52
|
+
this.keydownEvent.emit(event);
|
53
|
+
}
|
54
|
+
onKeypress(event) {
|
55
|
+
this.keypressEvent.emit(event);
|
56
|
+
}
|
57
|
+
writeValue(value) {
|
58
|
+
this.value = value;
|
59
|
+
}
|
60
|
+
registerOnChange(fn) {
|
61
|
+
this.onChangeCallback = fn;
|
62
|
+
}
|
63
|
+
registerOnTouched(fn) {
|
64
|
+
this.onTouchedCallback = fn;
|
65
|
+
}
|
66
|
+
setDisabledState(isDisabled) {
|
67
|
+
this.disabled = isDisabled;
|
68
|
+
}
|
69
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TextareaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
70
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TextareaComponent, selector: "sim-app-textarea", inputs: { label: "label", placeholder: "placeholder", id: "id", rows: "rows", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", autofocus: "autofocus", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
|
71
|
+
{
|
72
|
+
provide: NG_VALUE_ACCESSOR,
|
73
|
+
useExisting: forwardRef(() => TextareaComponent),
|
74
|
+
multi: true
|
75
|
+
}
|
76
|
+
], ngImport: i0, template: `
|
77
|
+
<div class="form-group" [ngStyle]="{
|
78
|
+
'margin-top': marginTop + 'rem',
|
79
|
+
'margin-bottom': marginBottom + 'rem',
|
80
|
+
'margin-left': marginLeft + 'rem',
|
81
|
+
'margin-right': marginRight + 'rem'
|
82
|
+
}">
|
83
|
+
<label [for]="id" class="form-label">{{ label }}</label>
|
84
|
+
<textarea class="form-control custom-textarea"
|
85
|
+
[id]="id"
|
86
|
+
[rows]="rows"
|
87
|
+
[placeholder]="placeholder"
|
88
|
+
[value]="value"
|
89
|
+
(input)="onInput($event)"
|
90
|
+
(change)="onChange($event)"
|
91
|
+
(focus)="onFocus($event)"
|
92
|
+
(blur)="onBlur($event)"
|
93
|
+
(keyup)="onKeyup($event)"
|
94
|
+
(keydown)="onKeydown($event)"
|
95
|
+
(keypress)="onKeypress($event)"
|
96
|
+
[attr.maxlength]="maxlength"
|
97
|
+
[attr.minlength]="minlength"
|
98
|
+
[required]="required"
|
99
|
+
[disabled]="disabled"
|
100
|
+
[readonly]="readonly"
|
101
|
+
[autofocus]="autofocus"></textarea>
|
102
|
+
</div>
|
103
|
+
`, isInline: true, styles: [".form-group{margin-bottom:1rem}.form-label{font-family:Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
104
|
+
}
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TextareaComponent, decorators: [{
|
106
|
+
type: Component,
|
107
|
+
args: [{ selector: 'sim-app-textarea', template: `
|
108
|
+
<div class="form-group" [ngStyle]="{
|
109
|
+
'margin-top': marginTop + 'rem',
|
110
|
+
'margin-bottom': marginBottom + 'rem',
|
111
|
+
'margin-left': marginLeft + 'rem',
|
112
|
+
'margin-right': marginRight + 'rem'
|
113
|
+
}">
|
114
|
+
<label [for]="id" class="form-label">{{ label }}</label>
|
115
|
+
<textarea class="form-control custom-textarea"
|
116
|
+
[id]="id"
|
117
|
+
[rows]="rows"
|
118
|
+
[placeholder]="placeholder"
|
119
|
+
[value]="value"
|
120
|
+
(input)="onInput($event)"
|
121
|
+
(change)="onChange($event)"
|
122
|
+
(focus)="onFocus($event)"
|
123
|
+
(blur)="onBlur($event)"
|
124
|
+
(keyup)="onKeyup($event)"
|
125
|
+
(keydown)="onKeydown($event)"
|
126
|
+
(keypress)="onKeypress($event)"
|
127
|
+
[attr.maxlength]="maxlength"
|
128
|
+
[attr.minlength]="minlength"
|
129
|
+
[required]="required"
|
130
|
+
[disabled]="disabled"
|
131
|
+
[readonly]="readonly"
|
132
|
+
[autofocus]="autofocus"></textarea>
|
133
|
+
</div>
|
134
|
+
`, providers: [
|
135
|
+
{
|
136
|
+
provide: NG_VALUE_ACCESSOR,
|
137
|
+
useExisting: forwardRef(() => TextareaComponent),
|
138
|
+
multi: true
|
139
|
+
}
|
140
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, styles: [".form-group{margin-bottom:1rem}.form-label{font-family:Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}\n"] }]
|
141
|
+
}], propDecorators: { label: [{
|
142
|
+
type: Input
|
143
|
+
}], placeholder: [{
|
144
|
+
type: Input
|
145
|
+
}], id: [{
|
146
|
+
type: Input
|
147
|
+
}], rows: [{
|
148
|
+
type: Input
|
149
|
+
}], disabled: [{
|
150
|
+
type: Input
|
151
|
+
}], readonly: [{
|
152
|
+
type: Input
|
153
|
+
}], maxlength: [{
|
154
|
+
type: Input
|
155
|
+
}], minlength: [{
|
156
|
+
type: Input
|
157
|
+
}], required: [{
|
158
|
+
type: Input
|
159
|
+
}], autofocus: [{
|
160
|
+
type: Input
|
161
|
+
}], marginTop: [{
|
162
|
+
type: Input
|
163
|
+
}], marginBottom: [{
|
164
|
+
type: Input
|
165
|
+
}], marginLeft: [{
|
166
|
+
type: Input
|
167
|
+
}], marginRight: [{
|
168
|
+
type: Input
|
169
|
+
}], inputEvent: [{
|
170
|
+
type: Output
|
171
|
+
}], changeEvent: [{
|
172
|
+
type: Output
|
173
|
+
}], focusEvent: [{
|
174
|
+
type: Output
|
175
|
+
}], blurEvent: [{
|
176
|
+
type: Output
|
177
|
+
}], keyupEvent: [{
|
178
|
+
type: Output
|
179
|
+
}], keydownEvent: [{
|
180
|
+
type: Output
|
181
|
+
}], keypressEvent: [{
|
182
|
+
type: Output
|
183
|
+
}] } });
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/textarea/textarea.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'sim-app-textarea',\n  template: `\n    <div class=\"form-group\" [ngStyle]=\"{\n      'margin-top': marginTop + 'rem',\n      'margin-bottom': marginBottom + 'rem',\n      'margin-left': marginLeft + 'rem',\n      'margin-right': marginRight + 'rem'\n    }\">\n      <label [for]=\"id\" class=\"form-label\">{{ label }}</label>\n      <textarea class=\"form-control custom-textarea\"\n                [id]=\"id\"\n                [rows]=\"rows\"\n                [placeholder]=\"placeholder\"\n                [value]=\"value\"\n                (input)=\"onInput($event)\"\n                (change)=\"onChange($event)\"\n                (focus)=\"onFocus($event)\"\n                (blur)=\"onBlur($event)\"\n                (keyup)=\"onKeyup($event)\"\n                (keydown)=\"onKeydown($event)\"\n                (keypress)=\"onKeypress($event)\"\n                [attr.maxlength]=\"maxlength\"\n                [attr.minlength]=\"minlength\"\n                [required]=\"required\"\n                [disabled]=\"disabled\"\n                [readonly]=\"readonly\"\n                [autofocus]=\"autofocus\"></textarea>\n    </div>\n  `,\n  styles: [`\n    .form-group {\n      margin-bottom: 1rem;\n    }\n    .form-label {\n      font-family: Arial, sans-serif;\n      color: #333;\n      font-size: 1rem;\n      font-weight: bold;\n    }\n  `],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TextareaComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TextareaComponent implements ControlValueAccessor {\n  @Input() label: string = 'Default Label';\n  @Input() placeholder: string = 'Default Placeholder';\n  @Input() id: string = 'textareaId';\n  @Input() rows: number = 3;\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() maxlength: number | null = null;\n  @Input() minlength: number | null = null;\n  @Input() required: boolean = false;\n  @Input() autofocus: boolean = false;\n\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n\n  @Output() inputEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() changeEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() focusEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() blurEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() keyupEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keydownEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keypressEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n  private onChangeCallback: (_: any) => void = () => { };\n  private onTouchedCallback: () => void = () => { };\n\n  value: string = '';\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLTextAreaElement;\n    this.value = inputElement.value;\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  onChange(event: Event) {\n    this.changeEvent.emit(event);\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focusEvent.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.onTouchedCallback();\n    this.blurEvent.emit(event);\n  }\n\n  onKeyup(event: KeyboardEvent) {\n    this.keyupEvent.emit(event);\n  }\n\n  onKeydown(event: KeyboardEvent) {\n    this.keydownEvent.emit(event);\n  }\n\n  onKeypress(event: KeyboardEvent) {\n    this.keypressEvent.emit(event);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n}\n"]}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
export var ButtonClasses;
|
2
|
+
(function (ButtonClasses) {
|
3
|
+
ButtonClasses["Primary"] = "btn-primary";
|
4
|
+
ButtonClasses["Secondary"] = "btn-secondary";
|
5
|
+
ButtonClasses["Success"] = "btn-success";
|
6
|
+
ButtonClasses["Danger"] = "btn-danger";
|
7
|
+
ButtonClasses["Warning"] = "btn-warning";
|
8
|
+
ButtonClasses["Info"] = "btn-info";
|
9
|
+
ButtonClasses["Light"] = "btn-light";
|
10
|
+
ButtonClasses["Dark"] = "btn-dark";
|
11
|
+
ButtonClasses["Link"] = "btn-link";
|
12
|
+
})(ButtonClasses || (ButtonClasses = {}));
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQnV0dG9uQ2xhc3Nlc0VudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9lbnVtL0J1dHRvbkNsYXNzZXNFbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGFBVVg7QUFWRCxXQUFZLGFBQWE7SUFDdkIsd0NBQXVCLENBQUE7SUFDdkIsNENBQTJCLENBQUE7SUFDM0Isd0NBQXVCLENBQUE7SUFDdkIsc0NBQXFCLENBQUE7SUFDckIsd0NBQXVCLENBQUE7SUFDdkIsa0NBQWlCLENBQUE7SUFDakIsb0NBQW1CLENBQUE7SUFDbkIsa0NBQWlCLENBQUE7SUFDakIsa0NBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQVZXLGFBQWEsS0FBYixhQUFhLFFBVXhCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gQnV0dG9uQ2xhc3NlcyB7XG4gIFByaW1hcnkgPSAnYnRuLXByaW1hcnknLFxuICBTZWNvbmRhcnkgPSAnYnRuLXNlY29uZGFyeScsXG4gIFN1Y2Nlc3MgPSAnYnRuLXN1Y2Nlc3MnLFxuICBEYW5nZXIgPSAnYnRuLWRhbmdlcicsXG4gIFdhcm5pbmcgPSAnYnRuLXdhcm5pbmcnLFxuICBJbmZvID0gJ2J0bi1pbmZvJyxcbiAgTGlnaHQgPSAnYnRuLWxpZ2h0JyxcbiAgRGFyayA9ICdidG4tZGFyaycsXG4gIExpbmsgPSAnYnRuLWxpbmsnXG59XG4iXX0=
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { ComponentsModule } from './components/components.module';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
export class LibPortalAngularModule {
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
6
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, imports: [ComponentsModule], exports: [ComponentsModule] }); }
|
7
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, imports: [ComponentsModule, ComponentsModule] }); }
|
8
|
+
}
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, decorators: [{
|
10
|
+
type: NgModule,
|
11
|
+
args: [{
|
12
|
+
imports: [
|
13
|
+
ComponentsModule,
|
14
|
+
],
|
15
|
+
exports: [
|
16
|
+
ComponentsModule
|
17
|
+
]
|
18
|
+
}]
|
19
|
+
}] });
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGliLXBvcnRhbC1hbmd1bGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2xpYi1wb3J0YWwtYW5ndWxhci9zcmMvbGliL2xpYi1wb3J0YWwtYW5ndWxhci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFVbEUsTUFBTSxPQUFPLHNCQUFzQjsrR0FBdEIsc0JBQXNCO2dIQUF0QixzQkFBc0IsWUFOL0IsZ0JBQWdCLGFBR2hCLGdCQUFnQjtnSEFHUCxzQkFBc0IsWUFOL0IsZ0JBQWdCLEVBR2hCLGdCQUFnQjs7NEZBR1Asc0JBQXNCO2tCQVJsQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxnQkFBZ0I7cUJBQ2pCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxnQkFBZ0I7cUJBQ2pCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudHNNb2R1bGUgfSBmcm9tICcuL2NvbXBvbmVudHMvY29tcG9uZW50cy5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tcG9uZW50c01vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIENvbXBvbmVudHNNb2R1bGVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBMaWJQb3J0YWxBbmd1bGFyTW9kdWxlIHsgfVxuIl19
|
@@ -0,0 +1,5 @@
|
|
1
|
+
/**
|
2
|
+
* Generated bundle index. Do not edit.
|
3
|
+
*/
|
4
|
+
export * from './public-api';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGliLXBvcnRhbC1hbmd1bGFyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbGliLXBvcnRhbC1hbmd1bGFyL3NyYy9saWItcG9ydGFsLWFuZ3VsYXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
@@ -0,0 +1,28 @@
|
|
1
|
+
/*
|
2
|
+
* Public API Surface of sim-lib
|
3
|
+
*
|
4
|
+
* Este arquivo exporta todos os componentes, enums e módulos necessários
|
5
|
+
* para que os consumidores da biblioteca possam utilizá-los em suas aplicações.
|
6
|
+
*/
|
7
|
+
// Componentes
|
8
|
+
export * from './lib/components/advanced-calendar/calendar.component';
|
9
|
+
export * from './lib/components/advanced-calendar/date-picker.component';
|
10
|
+
export * from './lib/components/advanced-calendar/date-time-picker.component';
|
11
|
+
export * from './lib/components/badge/badge.component';
|
12
|
+
export * from './lib/components/button/button.component';
|
13
|
+
export * from './lib/components/card/card.component';
|
14
|
+
export * from './lib/components/checkbox/checkbox.component';
|
15
|
+
export * from './lib/components/code-highlight/code-highlight.component';
|
16
|
+
export * from './lib/components/form/form.component';
|
17
|
+
export * from './lib/components/imput/input.component';
|
18
|
+
export * from './lib/components/multi-select/multi-select.component';
|
19
|
+
export * from './lib/components/radio/radio.component';
|
20
|
+
export * from './lib/components/select/select.component';
|
21
|
+
export * from './lib/components/tables/bootstrap-table.component';
|
22
|
+
export * from './lib/components/textarea/textarea.component';
|
23
|
+
// Enums
|
24
|
+
export * from './lib/enum/ButtonClassesEnum';
|
25
|
+
// Módulos
|
26
|
+
export * from './lib/components/components.module';
|
27
|
+
export * from './lib/lib-portal-angular.module';
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2xpYi1wb3J0YWwtYW5ndWxhci9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7R0FLRztBQUVILGNBQWM7QUFDZCxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyw4Q0FBOEMsQ0FBQztBQUU3RCxRQUFRO0FBQ1IsY0FBYyw4QkFBOEIsQ0FBQztBQUU3QyxVQUFVO0FBQ1YsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLGlDQUFpQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBzaW0tbGliXG4gKlxuICogRXN0ZSBhcnF1aXZvIGV4cG9ydGEgdG9kb3Mgb3MgY29tcG9uZW50ZXMsIGVudW1zIGUgbcOzZHVsb3MgbmVjZXNzw6FyaW9zXG4gKiBwYXJhIHF1ZSBvcyBjb25zdW1pZG9yZXMgZGEgYmlibGlvdGVjYSBwb3NzYW0gdXRpbGl6w6EtbG9zIGVtIHN1YXMgYXBsaWNhw6fDtWVzLlxuICovXG5cbi8vIENvbXBvbmVudGVzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2FkdmFuY2VkLWNhbGVuZGFyL2NhbGVuZGFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2FkdmFuY2VkLWNhbGVuZGFyL2RhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2FkdmFuY2VkLWNhbGVuZGFyL2RhdGUtdGltZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvYmFkZ2UvYmFkZ2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jYXJkL2NhcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY29kZS1oaWdobGlnaHQvY29kZS1oaWdobGlnaHQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2ltcHV0L2lucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL211bHRpLXNlbGVjdC9tdWx0aS1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvcmFkaW8vcmFkaW8uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvc2VsZWN0L3NlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90YWJsZXMvYm9vdHN0cmFwLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RleHRhcmVhL3RleHRhcmVhLmNvbXBvbmVudCc7XG5cbi8vIEVudW1zXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnVtL0J1dHRvbkNsYXNzZXNFbnVtJztcblxuLy8gTcOzZHVsb3NcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY29tcG9uZW50cy5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXBvcnRhbC1hbmd1bGFyLm1vZHVsZSc7XG5cblxuIl19
|