ngx-vector-components 0.0.5 → 0.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/fields/currency-field/currency-field.component.mjs +13 -4
- package/esm2020/lib/components/fields/dropdown-field/dropdown-field.component.mjs +7 -7
- package/esm2020/lib/components/fields/filters/filters.component.mjs +1 -1
- package/esm2020/lib/guards/get-token-by-guid.guard.mjs +48 -0
- package/esm2020/lib/guards/has-permission.guard.mjs +27 -0
- package/esm2020/lib/guards/index.mjs +5 -0
- package/esm2020/lib/guards/role.guard.mjs +24 -0
- package/esm2020/lib/guards/token-is-present.guard.mjs +17 -0
- package/esm2020/lib/models/http-response.model.mjs +1 -1
- package/esm2020/lib/services/auth.service.mjs +2 -2
- package/esm2020/lib/services/storage.service.mjs +9 -3
- package/esm2020/lib/utils/mask.util.mjs +5 -1
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/ngx-vector-components.mjs +184 -63
- package/fesm2015/ngx-vector-components.mjs.map +1 -1
- package/fesm2020/ngx-vector-components.mjs +174 -59
- package/fesm2020/ngx-vector-components.mjs.map +1 -1
- package/lib/components/fields/currency-field/currency-field.component.d.ts +4 -1
- package/lib/components/fields/dropdown-field/dropdown-field.component.d.ts +2 -2
- package/lib/guards/get-token-by-guid.guard.d.ts +14 -0
- package/lib/guards/has-permission.guard.d.ts +13 -0
- package/lib/guards/index.d.ts +4 -0
- package/lib/guards/role.guard.d.ts +11 -0
- package/lib/guards/token-is-present.guard.d.ts +10 -0
- package/lib/models/http-response.model.d.ts +1 -1
- package/lib/services/storage.service.d.ts +2 -2
- package/lib/utils/mask.util.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -7,6 +7,9 @@ import * as i2 from "@angular/common";
|
|
|
7
7
|
import * as i3 from "@angular/forms";
|
|
8
8
|
export class CurrencyFieldComponent {
|
|
9
9
|
constructor() {
|
|
10
|
+
this.minValue = 0;
|
|
11
|
+
this.maxValue = 999999999;
|
|
12
|
+
this.placeholder = '';
|
|
10
13
|
this.outlined = false;
|
|
11
14
|
this.lastInvertedIndexTyped = 0;
|
|
12
15
|
this.subscription = new Subscription();
|
|
@@ -73,7 +76,7 @@ export class CurrencyFieldComponent {
|
|
|
73
76
|
return returnValue;
|
|
74
77
|
}));
|
|
75
78
|
const newValueOnlyNumbers = newValue.replace(/[^0-9]/g, '');
|
|
76
|
-
target.value = Number(`${newValueOnlyNumbers.
|
|
79
|
+
target.value = Number(`${newValueOnlyNumbers.substring(0, newValueOnlyNumbers.length - 2)}.${newValueOnlyNumbers.substr(newValueOnlyNumbers.length - 2)}`).toLocaleString('pt-BR', {
|
|
77
80
|
currency: 'BRL',
|
|
78
81
|
minimumFractionDigits: 2,
|
|
79
82
|
maximumFractionDigits: 2,
|
|
@@ -85,13 +88,19 @@ export class CurrencyFieldComponent {
|
|
|
85
88
|
}
|
|
86
89
|
}
|
|
87
90
|
CurrencyFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CurrencyFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
-
CurrencyFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CurrencyFieldComponent, selector: "vector-currency-field", inputs: { control: "control", outlined: "outlined" }, ngImport: i0, template: "<div [ngClass]=\"{ 'input-container': outlined, 'value-input-container': !outlined }\">\r\n <span *ngIf=\"!outlined\">R$ </span>\r\n <div class=\"value-input\">\r\n <p-inputNumber\r\n class=\"currency-input\"\r\n [ngClass]=\"{outlined}\"\r\n [formControl]=\"control\"\r\n mode=\"decimal\"\r\n [minFractionDigits]=\"2\"\r\n [maxFractionDigits]=\"2\"\r\n [max]=\"999999999\"\r\n [prefix]=\"outlined ? 'R$ ' : ''\"\r\n (click)=\"focusLastIndex($event)\"\r\n (onKeyDown)=\"inputNextChar($event)\"\r\n ></p-inputNumber>\r\n </div>\r\n</div>\r\n", styles: [".value-input-container{display:flex;flex-direction:row;align-items:center;padding:5px 20px}.value-input-container span{font-size:2em;font-weight:700;color:#3a2b68}.value-input-container .value-input{margin:0 4px;flex:1}\n"], components: [{ type: i1.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
91
|
+
CurrencyFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CurrencyFieldComponent, selector: "vector-currency-field", inputs: { minValue: "minValue", maxValue: "maxValue", placeholder: "placeholder", control: "control", outlined: "outlined" }, ngImport: i0, template: "<div [ngClass]=\"{ 'input-container': outlined, 'value-input-container': !outlined }\">\r\n <span *ngIf=\"!outlined\">R$ </span>\r\n <div class=\"value-input\">\r\n <p-inputNumber\r\n class=\"currency-input\"\r\n [ngClass]=\"{outlined}\"\r\n [formControl]=\"control\"\r\n mode=\"decimal\"\r\n [minFractionDigits]=\"2\"\r\n [maxFractionDigits]=\"2\"\r\n [max]=\"999999999\"\r\n [prefix]=\"outlined ? 'R$ ' : ''\"\r\n (click)=\"focusLastIndex($event)\"\r\n (onKeyDown)=\"inputNextChar($event)\"\r\n ></p-inputNumber>\r\n </div>\r\n</div>\r\n", styles: [".value-input-container{display:flex;flex-direction:row;align-items:center;padding:5px 20px}.value-input-container span{font-size:2em;font-weight:700;color:#3a2b68}.value-input-container .value-input{margin:0 4px;flex:1}\n"], components: [{ type: i1.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
89
92
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CurrencyFieldComponent, decorators: [{
|
|
90
93
|
type: Component,
|
|
91
94
|
args: [{ selector: 'vector-currency-field', template: "<div [ngClass]=\"{ 'input-container': outlined, 'value-input-container': !outlined }\">\r\n <span *ngIf=\"!outlined\">R$ </span>\r\n <div class=\"value-input\">\r\n <p-inputNumber\r\n class=\"currency-input\"\r\n [ngClass]=\"{outlined}\"\r\n [formControl]=\"control\"\r\n mode=\"decimal\"\r\n [minFractionDigits]=\"2\"\r\n [maxFractionDigits]=\"2\"\r\n [max]=\"999999999\"\r\n [prefix]=\"outlined ? 'R$ ' : ''\"\r\n (click)=\"focusLastIndex($event)\"\r\n (onKeyDown)=\"inputNextChar($event)\"\r\n ></p-inputNumber>\r\n </div>\r\n</div>\r\n", styles: [".value-input-container{display:flex;flex-direction:row;align-items:center;padding:5px 20px}.value-input-container span{font-size:2em;font-weight:700;color:#3a2b68}.value-input-container .value-input{margin:0 4px;flex:1}\n"] }]
|
|
92
|
-
}], propDecorators: {
|
|
95
|
+
}], propDecorators: { minValue: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], maxValue: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}], placeholder: [{
|
|
100
|
+
type: Input
|
|
101
|
+
}], control: [{
|
|
93
102
|
type: Input
|
|
94
103
|
}], outlined: [{
|
|
95
104
|
type: Input
|
|
96
105
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/currency-field/currency-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/currency-field/currency-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { StringUtil } from '../../../utils';\r\n\r\n@Component({\r\n  selector: 'vector-currency-field',\r\n  templateUrl: './currency-field.component.html',\r\n  styleUrls: ['./currency-field.component.scss'],\r\n})\r\nexport class CurrencyFieldComponent implements OnDestroy {\r\n  @Input()\r\n  set control(_control: any) {\r\n    this._control = _control;\r\n    if (this.control.value) {\r\n      this.lastInvertedIndexTyped = `${this.control.value}`.length;\r\n    }\r\n\r\n    this.subscription.add(\r\n      this.control.valueChanges.subscribe((value: string) => {\r\n        if (value) {\r\n          this.lastInvertedIndexTyped = `${value}`.length;\r\n        }\r\n      })\r\n    );\r\n  }\r\n  @Input()\r\n  public outlined = false;\r\n\r\n  get control() {\r\n    return this._control;\r\n  }\r\n\r\n  private _control: any;\r\n  private lastInvertedIndexTyped = 0;\r\n  private subscription = new Subscription();\r\n\r\n  ngOnDestroy() {\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  public focusLastIndex($event: Event): void {\r\n    const target = $event.target as HTMLInputElement;\r\n    const selectionIndex = target?.value.length || 0;\r\n    target?.setSelectionRange(selectionIndex, selectionIndex);\r\n  }\r\n\r\n  public inputNextChar($event: KeyboardEvent): void {\r\n    this.focusLastIndex($event);\r\n    const target = $event.target as HTMLInputElement;\r\n    const isDeleteOrBackspace = ['Delete', 'Backspace'].includes($event.key);\r\n    if (isDeleteOrBackspace) {\r\n      this.lastInvertedIndexTyped--;\r\n      target.value = target.value.substr(0, target.value.length - 1);\r\n      if (target.value === '') {\r\n        this.lastInvertedIndexTyped = 0;\r\n        target.value = '0,00';\r\n        return;\r\n      }\r\n    }\r\n    let valueTyped = $event.key;\r\n    if (!isNaN(+valueTyped) || isDeleteOrBackspace) {\r\n      if (target.value === '0,00' && +valueTyped === 0) {\r\n        return;\r\n      }\r\n\r\n      if (isDeleteOrBackspace) {\r\n        valueTyped = '';\r\n      }\r\n\r\n      let i = 0;\r\n      const reversedPreviousValue = StringUtil.revertString(target.value.replace(/[^0-9]/g, ''));\r\n      const newValue = StringUtil.revertString(\r\n        StringUtil.revertString(\r\n          this.lastInvertedIndexTyped >= 3 ? `${target.value}${valueTyped}`.replace(/[0-9]/g, '#') : '#,##'\r\n        ).replace(/#/g, () => {\r\n          let returnValue = '0';\r\n          if (isDeleteOrBackspace) {\r\n            returnValue = reversedPreviousValue[i];\r\n          } else {\r\n            if (i === 0) {\r\n              returnValue = `${valueTyped}`;\r\n            } else {\r\n              returnValue = reversedPreviousValue[i - 1] || '0';\r\n            }\r\n          }\r\n\r\n          i++;\r\n          return returnValue;\r\n        })\r\n      );\r\n      const newValueOnlyNumbers = newValue.replace(/[^0-9]/g, '');\r\n      target.value = Number(\r\n        `${newValueOnlyNumbers.substr(0, newValueOnlyNumbers.length - 2)}.${newValueOnlyNumbers.substr(\r\n          newValueOnlyNumbers.length - 2\r\n        )}`\r\n      ).toLocaleString('pt-BR', {\r\n        currency: 'BRL',\r\n        minimumFractionDigits: 2,\r\n        maximumFractionDigits: 2,\r\n      });\r\n      if (!isNaN(+valueTyped)) {\r\n        this.lastInvertedIndexTyped++;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div [ngClass]=\"{ 'input-container': outlined, 'value-input-container': !outlined }\">\r\n  <span *ngIf=\"!outlined\">R$ </span>\r\n  <div class=\"value-input\">\r\n    <p-inputNumber\r\n      class=\"currency-input\"\r\n      [ngClass]=\"{outlined}\"\r\n      [formControl]=\"control\"\r\n      mode=\"decimal\"\r\n      [minFractionDigits]=\"2\"\r\n      [maxFractionDigits]=\"2\"\r\n      [max]=\"999999999\"\r\n      [prefix]=\"outlined ? 'R$ ' : ''\"\r\n      (click)=\"focusLastIndex($event)\"\r\n      (onKeyDown)=\"inputNextChar($event)\"\r\n    ></p-inputNumber>\r\n  </div>\r\n</div>\r\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/currency-field/currency-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/currency-field/currency-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { StringUtil } from '../../../utils';\r\n\r\n@Component({\r\n  selector: 'vector-currency-field',\r\n  templateUrl: './currency-field.component.html',\r\n  styleUrls: ['./currency-field.component.scss'],\r\n})\r\nexport class CurrencyFieldComponent implements OnDestroy {\r\n  @Input()\r\n  public minValue = 0;\r\n  @Input()\r\n  public maxValue = 999999999;\r\n  @Input()\r\n  public placeholder: string = '';\r\n  @Input()\r\n  set control(_control: any) {\r\n    this._control = _control;\r\n    if (this.control.value) {\r\n      this.lastInvertedIndexTyped = `${this.control.value}`.length;\r\n    }\r\n\r\n    this.subscription.add(\r\n      this.control.valueChanges.subscribe((value: string) => {\r\n        if (value) {\r\n          this.lastInvertedIndexTyped = `${value}`.length;\r\n        }\r\n      })\r\n    );\r\n  }\r\n  @Input()\r\n  public outlined = false;\r\n\r\n  get control() {\r\n    return this._control;\r\n  }\r\n\r\n  private _control: any;\r\n  private lastInvertedIndexTyped = 0;\r\n  private subscription = new Subscription();\r\n\r\n  ngOnDestroy() {\r\n    this.subscription.unsubscribe();\r\n  }\r\n\r\n  public focusLastIndex($event: Event): void {\r\n    const target = $event.target as HTMLInputElement;\r\n    const selectionIndex = target?.value.length || 0;\r\n    target?.setSelectionRange(selectionIndex, selectionIndex);\r\n  }\r\n\r\n  public inputNextChar($event: KeyboardEvent): void {\r\n    this.focusLastIndex($event);\r\n    const target = $event.target as HTMLInputElement;\r\n    const isDeleteOrBackspace = ['Delete', 'Backspace'].includes($event.key);\r\n    if (isDeleteOrBackspace) {\r\n      this.lastInvertedIndexTyped--;\r\n      target.value = target.value.substr(0, target.value.length - 1);\r\n      if (target.value === '') {\r\n        this.lastInvertedIndexTyped = 0;\r\n        target.value = '0,00';\r\n        return;\r\n      }\r\n    }\r\n    let valueTyped = $event.key;\r\n    if (!isNaN(+valueTyped) || isDeleteOrBackspace) {\r\n      if (target.value === '0,00' && +valueTyped === 0) {\r\n        return;\r\n      }\r\n\r\n      if (isDeleteOrBackspace) {\r\n        valueTyped = '';\r\n      }\r\n\r\n      let i = 0;\r\n      const reversedPreviousValue = StringUtil.revertString(target.value.replace(/[^0-9]/g, ''));\r\n      const newValue = StringUtil.revertString(\r\n        StringUtil.revertString(\r\n          this.lastInvertedIndexTyped >= 3 ? `${target.value}${valueTyped}`.replace(/[0-9]/g, '#') : '#,##'\r\n        ).replace(/#/g, () => {\r\n          let returnValue = '0';\r\n          if (isDeleteOrBackspace) {\r\n            returnValue = reversedPreviousValue[i];\r\n          } else {\r\n            if (i === 0) {\r\n              returnValue = `${valueTyped}`;\r\n            } else {\r\n              returnValue = reversedPreviousValue[i - 1] || '0';\r\n            }\r\n          }\r\n\r\n          i++;\r\n          return returnValue;\r\n        })\r\n      );\r\n      const newValueOnlyNumbers = newValue.replace(/[^0-9]/g, '');\r\n      target.value = Number(\r\n        `${newValueOnlyNumbers.substring(0, newValueOnlyNumbers.length - 2)}.${newValueOnlyNumbers.substr(\r\n          newValueOnlyNumbers.length - 2\r\n        )}`\r\n      ).toLocaleString('pt-BR', {\r\n        currency: 'BRL',\r\n        minimumFractionDigits: 2,\r\n        maximumFractionDigits: 2,\r\n      });\r\n      if (!isNaN(+valueTyped)) {\r\n        this.lastInvertedIndexTyped++;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div [ngClass]=\"{ 'input-container': outlined, 'value-input-container': !outlined }\">\r\n  <span *ngIf=\"!outlined\">R$ </span>\r\n  <div class=\"value-input\">\r\n    <p-inputNumber\r\n      class=\"currency-input\"\r\n      [ngClass]=\"{outlined}\"\r\n      [formControl]=\"control\"\r\n      mode=\"decimal\"\r\n      [minFractionDigits]=\"2\"\r\n      [maxFractionDigits]=\"2\"\r\n      [max]=\"999999999\"\r\n      [prefix]=\"outlined ? 'R$ ' : ''\"\r\n      (click)=\"focusLastIndex($event)\"\r\n      (onKeyDown)=\"inputNextChar($event)\"\r\n    ></p-inputNumber>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -24,7 +24,7 @@ export class DropdownFieldComponent {
|
|
|
24
24
|
}
|
|
25
25
|
set options(_options) {
|
|
26
26
|
this._options = _options;
|
|
27
|
-
this.pagedSuggestions = this.options;
|
|
27
|
+
this.pagedSuggestions = this.options || [];
|
|
28
28
|
}
|
|
29
29
|
set control(_control) {
|
|
30
30
|
this._control = _control;
|
|
@@ -93,7 +93,7 @@ export class DropdownFieldComponent {
|
|
|
93
93
|
if (this.service) {
|
|
94
94
|
this.currentScrollPage++;
|
|
95
95
|
this.service.getPaged(this.currentSearchQuery, this.currentScrollPage, 20, this.dependencies).subscribe((response) => {
|
|
96
|
-
this.pagedSuggestions = this.currentScrollPage === 0 ? response : this.pagedSuggestions
|
|
96
|
+
this.pagedSuggestions = this.currentScrollPage === 0 ? response : this.pagedSuggestions?.concat(response);
|
|
97
97
|
this.isLoading = false;
|
|
98
98
|
this.setControlValueFromSuggestions();
|
|
99
99
|
this.handleSearchErrors();
|
|
@@ -104,7 +104,7 @@ export class DropdownFieldComponent {
|
|
|
104
104
|
else {
|
|
105
105
|
const filteredOptions = this.filterListByQuery(this.options, this.currentSearchQuery.toUpperCase());
|
|
106
106
|
this.pagedSuggestions = filteredOptions.slice(0, this.currentScrollIndex + 20);
|
|
107
|
-
if (this.options.length > 20) {
|
|
107
|
+
if (this.options?.length && this.options.length > 20) {
|
|
108
108
|
this.currentScrollIndex = this.currentScrollIndex + 20;
|
|
109
109
|
}
|
|
110
110
|
this.setControlValueFromSuggestions();
|
|
@@ -112,7 +112,7 @@ export class DropdownFieldComponent {
|
|
|
112
112
|
}
|
|
113
113
|
}
|
|
114
114
|
setControlValueFromSuggestions() {
|
|
115
|
-
if (this.control.value && this.pagedSuggestions
|
|
115
|
+
if (this.control.value && this.pagedSuggestions?.length) {
|
|
116
116
|
let itemsArray = this.pagedSuggestions;
|
|
117
117
|
if (this.options?.length) {
|
|
118
118
|
itemsArray = this.options;
|
|
@@ -122,14 +122,14 @@ export class DropdownFieldComponent {
|
|
|
122
122
|
}
|
|
123
123
|
}
|
|
124
124
|
handleSearchErrors() {
|
|
125
|
-
if (this.pagedSuggestions
|
|
125
|
+
if (this.pagedSuggestions?.length) {
|
|
126
126
|
delete this.control.errors?.itemNotFound;
|
|
127
127
|
}
|
|
128
128
|
else if (this.currentSearchQuery) {
|
|
129
129
|
this.control.setErrors({ itemNotFound: true });
|
|
130
130
|
}
|
|
131
131
|
}
|
|
132
|
-
filterListByQuery(list, query) {
|
|
132
|
+
filterListByQuery(list = [], query) {
|
|
133
133
|
return list.filter((opt) => opt.code.toString().toUpperCase().includes(query) || opt.name.toUpperCase().includes(query));
|
|
134
134
|
}
|
|
135
135
|
}
|
|
@@ -157,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
157
157
|
}], onFocus: [{
|
|
158
158
|
type: Output
|
|
159
159
|
}] } });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, Renderer2 } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport type DropdownButtonAction = {\r\n  label: string;\r\n  onClick: (value: any) => void;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-dropdown-field',\r\n  templateUrl: './dropdown-field.component.html',\r\n  styleUrls: ['./dropdown-field.component.scss'],\r\n})\r\nexport class DropdownFieldComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  set options(_options: ListItem[]) {\r\n    this._options = _options;\r\n    this.pagedSuggestions = this.options;\r\n  }\r\n  @Input()\r\n  public isRequired: boolean | undefined = false;\r\n  @Input()\r\n  set control(_control: any) {\r\n    this._control = _control;\r\n    if (this.control) {\r\n      this.subscription.add(\r\n        this.control.valueChanges.subscribe(() => {\r\n          this.setControlValueFromSuggestions();\r\n        })\r\n      );\r\n    }\r\n  }\r\n  @Input()\r\n  public label: string = '';\r\n  @Input()\r\n  public service: BaseDropdown | undefined;\r\n  @Input()\r\n  public paged = true;\r\n  @Input()\r\n  public buttonAction: DropdownButtonAction | undefined;\r\n  @Input()\r\n  public dependencies: any;\r\n  @Output()\r\n  public onFocus = new EventEmitter();\r\n\r\n  get control() {\r\n    return this._control;\r\n  }\r\n\r\n  get options() {\r\n    return this._options;\r\n  }\r\n\r\n  get placeholder() {\r\n    if (!this.label) {\r\n      return '';\r\n    }\r\n    return `${this.label}${this.isRequired ? '*' : ''}`;\r\n  }\r\n\r\n  public isLoading = false;\r\n  public pagedSuggestions: ListItem[] = [];\r\n  public unlistenAutocompleteVirtualScroll = () => {};\r\n\r\n  private _control: any;\r\n  private _options: ListItem[] = [];\r\n  private currentScrollPage = -1;\r\n  private currentScrollIndex = 0;\r\n  private subscription = new Subscription();\r\n  private currentSearchQuery = '';\r\n\r\n  constructor(private renderer: Renderer2) {}\r\n\r\n  ngOnInit(): void {\r\n    this.search();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscription.unsubscribe();\r\n    if (this.unlistenAutocompleteVirtualScroll) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  public fieldErrorLabel(): string {\r\n    if (this.control?.invalid && this.control.touched) {\r\n      if (this.control.hasError('required')) {\r\n        return 'Campo obrigatório';\r\n      }\r\n\r\n      return this.control?.errors && typeof this.control.errors['invalid'] === 'string'\r\n        ? this.control?.errors['invalid']\r\n        : 'Campo inválido';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  public search($event?: any): void {\r\n    this.currentSearchQuery = $event?.query.toUpperCase() || '';\r\n    this.currentScrollPage = -1;\r\n    this.currentScrollIndex = 0;\r\n    this.pageResults();\r\n  }\r\n\r\n  public onOpenAutocompletePanel(): void {\r\n    const autocompletePanel = document.querySelector('.p-autocomplete-panel');\r\n    if (autocompletePanel && this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll = this.renderer.listen(autocompletePanel, 'scroll', (event) => {\r\n        if (event.target.scrollHeight - event.target.clientHeight === Math.round(event.target.scrollTop)) {\r\n          this.pageResults();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public onHideAutocompletePanel(): void {\r\n    if (this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n    this.pagedSuggestions = [];\r\n  }\r\n\r\n  private pageResults(): void {\r\n    this.isLoading = true;\r\n    if (this.service) {\r\n      this.currentScrollPage++;\r\n      this.service.getPaged(this.currentSearchQuery, this.currentScrollPage, 20, this.dependencies).subscribe(\r\n        (response) => {\r\n          this.pagedSuggestions = this.currentScrollPage === 0 ? response : this.pagedSuggestions.concat(response);\r\n          this.isLoading = false;\r\n          this.setControlValueFromSuggestions();\r\n          this.handleSearchErrors();\r\n        },\r\n        (err) => {\r\n          this.isLoading = false;\r\n        }\r\n      );\r\n    } else {\r\n      const filteredOptions = this.filterListByQuery(this.options, this.currentSearchQuery.toUpperCase());\r\n      this.pagedSuggestions = filteredOptions.slice(0, this.currentScrollIndex + 20);\r\n\r\n      if (this.options.length > 20) {\r\n        this.currentScrollIndex = this.currentScrollIndex + 20;\r\n      }\r\n\r\n      this.setControlValueFromSuggestions();\r\n      this.handleSearchErrors();\r\n    }\r\n  }\r\n\r\n  private setControlValueFromSuggestions() {\r\n    if (this.control.value && this.pagedSuggestions.length) {\r\n      let itemsArray = this.pagedSuggestions;\r\n      if (this.options?.length) {\r\n        itemsArray = this.options;\r\n      }\r\n      this.control.setValue(\r\n        itemsArray.find(\r\n          (opt) =>\r\n            `${opt.code}` ===\r\n            ((ObjectUtil.isValid(this.control.value?.code) && `${this.control.value?.code}`) || `${this.control.value}`)\r\n        ),\r\n        { emitEvent: false }\r\n      );\r\n    }\r\n  }\r\n\r\n  private handleSearchErrors() {\r\n    if (this.pagedSuggestions.length) {\r\n      delete this.control.errors?.itemNotFound;\r\n    } else if (this.currentSearchQuery) {\r\n      this.control.setErrors({ itemNotFound: true });\r\n    }\r\n  }\r\n\r\n  private filterListByQuery(list: ListItem[], query: string): ListItem[] {\r\n    return list.filter(\r\n      (opt) => opt.code.toString().toUpperCase().includes(query) || opt.name.toUpperCase().includes(query)\r\n    );\r\n  }\r\n}\r\n","<div class=\"input-container\">\r\n  <p-autoComplete\r\n    appendTo=\"body\"\r\n    field=\"name\"\r\n    dataKey=\"code\"\r\n    [forceSelection]=\"true\"\r\n    [dropdown]=\"true\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [suggestions]=\"pagedSuggestions\"\r\n    (completeMethod)=\"search($event)\"\r\n    (onShow)=\"onOpenAutocompletePanel()\"\r\n    (onHide)=\"onHideAutocompletePanel()\"\r\n    (onFocus)=\"onFocus.emit($event)\"\r\n  >\r\n  </p-autoComplete>\r\n  <vector-button\r\n    *ngIf=\"buttonAction\"\r\n    [label]=\"buttonAction.label\"\r\n    [disabled]=\"!control.value\"\r\n    (onClick)=\"buttonAction.onClick(control.value)\"\r\n  ></vector-button>\r\n</div>\r\n"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/dropdown-field/dropdown-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, Renderer2 } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { ListItem } from '../../../models';\r\nimport { BaseDropdown } from '../../../services';\r\nimport { ObjectUtil } from '../../../utils';\r\n\r\nexport type DropdownButtonAction = {\r\n  label: string;\r\n  onClick: (value: any) => void;\r\n};\r\n\r\n@Component({\r\n  selector: 'vector-dropdown-field',\r\n  templateUrl: './dropdown-field.component.html',\r\n  styleUrls: ['./dropdown-field.component.scss'],\r\n})\r\nexport class DropdownFieldComponent implements OnInit, OnDestroy {\r\n  @Input()\r\n  set options(_options: ListItem[] | undefined) {\r\n    this._options = _options;\r\n    this.pagedSuggestions = this.options || [];\r\n  }\r\n  @Input()\r\n  public isRequired: boolean | undefined = false;\r\n  @Input()\r\n  set control(_control: any) {\r\n    this._control = _control;\r\n    if (this.control) {\r\n      this.subscription.add(\r\n        this.control.valueChanges.subscribe(() => {\r\n          this.setControlValueFromSuggestions();\r\n        })\r\n      );\r\n    }\r\n  }\r\n  @Input()\r\n  public label: string = '';\r\n  @Input()\r\n  public service: BaseDropdown | undefined;\r\n  @Input()\r\n  public paged = true;\r\n  @Input()\r\n  public buttonAction: DropdownButtonAction | undefined;\r\n  @Input()\r\n  public dependencies: any;\r\n  @Output()\r\n  public onFocus = new EventEmitter();\r\n\r\n  get control() {\r\n    return this._control;\r\n  }\r\n\r\n  get options() {\r\n    return this._options;\r\n  }\r\n\r\n  get placeholder() {\r\n    if (!this.label) {\r\n      return '';\r\n    }\r\n    return `${this.label}${this.isRequired ? '*' : ''}`;\r\n  }\r\n\r\n  public isLoading = false;\r\n  public pagedSuggestions: ListItem[] = [];\r\n  public unlistenAutocompleteVirtualScroll = () => {};\r\n\r\n  private _control: any;\r\n  private _options: ListItem[] | undefined = [];\r\n  private currentScrollPage = -1;\r\n  private currentScrollIndex = 0;\r\n  private subscription = new Subscription();\r\n  private currentSearchQuery = '';\r\n\r\n  constructor(private renderer: Renderer2) {}\r\n\r\n  ngOnInit(): void {\r\n    this.search();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscription.unsubscribe();\r\n    if (this.unlistenAutocompleteVirtualScroll) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n  }\r\n\r\n  public fieldErrorLabel(): string {\r\n    if (this.control?.invalid && this.control.touched) {\r\n      if (this.control.hasError('required')) {\r\n        return 'Campo obrigatório';\r\n      }\r\n\r\n      return this.control?.errors && typeof this.control.errors['invalid'] === 'string'\r\n        ? this.control?.errors['invalid']\r\n        : 'Campo inválido';\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  public search($event?: any): void {\r\n    this.currentSearchQuery = $event?.query.toUpperCase() || '';\r\n    this.currentScrollPage = -1;\r\n    this.currentScrollIndex = 0;\r\n    this.pageResults();\r\n  }\r\n\r\n  public onOpenAutocompletePanel(): void {\r\n    const autocompletePanel = document.querySelector('.p-autocomplete-panel');\r\n    if (autocompletePanel && this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll = this.renderer.listen(autocompletePanel, 'scroll', (event) => {\r\n        if (event.target.scrollHeight - event.target.clientHeight === Math.round(event.target.scrollTop)) {\r\n          this.pageResults();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public onHideAutocompletePanel(): void {\r\n    if (this.paged) {\r\n      this.unlistenAutocompleteVirtualScroll();\r\n    }\r\n    this.pagedSuggestions = [];\r\n  }\r\n\r\n  private pageResults(): void {\r\n    this.isLoading = true;\r\n    if (this.service) {\r\n      this.currentScrollPage++;\r\n      this.service.getPaged(this.currentSearchQuery, this.currentScrollPage, 20, this.dependencies).subscribe(\r\n        (response) => {\r\n          this.pagedSuggestions = this.currentScrollPage === 0 ? response : this.pagedSuggestions?.concat(response);\r\n          this.isLoading = false;\r\n          this.setControlValueFromSuggestions();\r\n          this.handleSearchErrors();\r\n        },\r\n        (err) => {\r\n          this.isLoading = false;\r\n        }\r\n      );\r\n    } else {\r\n      const filteredOptions = this.filterListByQuery(this.options, this.currentSearchQuery.toUpperCase());\r\n      this.pagedSuggestions = filteredOptions.slice(0, this.currentScrollIndex + 20);\r\n\r\n      if (this.options?.length && this.options.length > 20) {\r\n        this.currentScrollIndex = this.currentScrollIndex + 20;\r\n      }\r\n\r\n      this.setControlValueFromSuggestions();\r\n      this.handleSearchErrors();\r\n    }\r\n  }\r\n\r\n  private setControlValueFromSuggestions() {\r\n    if (this.control.value && this.pagedSuggestions?.length) {\r\n      let itemsArray = this.pagedSuggestions;\r\n      if (this.options?.length) {\r\n        itemsArray = this.options;\r\n      }\r\n      this.control.setValue(\r\n        itemsArray.find(\r\n          (opt) =>\r\n            `${opt.code}` ===\r\n            ((ObjectUtil.isValid(this.control.value?.code) && `${this.control.value?.code}`) || `${this.control.value}`)\r\n        ),\r\n        { emitEvent: false }\r\n      );\r\n    }\r\n  }\r\n\r\n  private handleSearchErrors() {\r\n    if (this.pagedSuggestions?.length) {\r\n      delete this.control.errors?.itemNotFound;\r\n    } else if (this.currentSearchQuery) {\r\n      this.control.setErrors({ itemNotFound: true });\r\n    }\r\n  }\r\n\r\n  private filterListByQuery(list: ListItem[] = [], query: string): ListItem[] {\r\n    return list.filter(\r\n      (opt) => opt.code.toString().toUpperCase().includes(query) || opt.name.toUpperCase().includes(query)\r\n    );\r\n  }\r\n}\r\n","<div class=\"input-container\">\r\n  <p-autoComplete\r\n    appendTo=\"body\"\r\n    field=\"name\"\r\n    dataKey=\"code\"\r\n    [forceSelection]=\"true\"\r\n    [dropdown]=\"true\"\r\n    [formControl]=\"control\"\r\n    [placeholder]=\"placeholder\"\r\n    [suggestions]=\"pagedSuggestions\"\r\n    (completeMethod)=\"search($event)\"\r\n    (onShow)=\"onOpenAutocompletePanel()\"\r\n    (onHide)=\"onHideAutocompletePanel()\"\r\n    (onFocus)=\"onFocus.emit($event)\"\r\n  >\r\n  </p-autoComplete>\r\n  <vector-button\r\n    *ngIf=\"buttonAction\"\r\n    [label]=\"buttonAction.label\"\r\n    [disabled]=\"!control.value\"\r\n    (onClick)=\"buttonAction.onClick(control.value)\"\r\n  ></vector-button>\r\n</div>\r\n"]}
|
|
@@ -116,7 +116,7 @@ export class FiltersComponent {
|
|
|
116
116
|
}
|
|
117
117
|
}
|
|
118
118
|
FiltersComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FiltersComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
119
|
-
FiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: FiltersComponent, selector: "vector-filters", inputs: { fields: "fields" }, outputs: { onSearch: "onSearch" }, ngImport: i0, template: "<section class=\"grid filter-container\" [hidden]=\"!fields?.length\">\r\n <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n <label>{{ field.label }}</label>\r\n <vector-text-field\r\n *ngIf=\"isTextFieldType(field)\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [mask]=\"field.mask\"\r\n [label]=\"field.placeholder\"\r\n [isRequired]=\"field.required\"\r\n [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n ></vector-text-field>\r\n <vector-dropdown-field\r\n *ngIf=\"field.type === fieldTypes.DROPDOWN\"\r\n [options]=\"field.options || []\"\r\n [service]=\"field.service\"\r\n [isRequired]=\"field.required\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [paged]=\"false\"\r\n [dependencies]=\"getFieldDependencies(field)\"\r\n ></vector-dropdown-field>\r\n <vector-currency-field\r\n *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [outlined]=\"true\"\r\n ></vector-currency-field>\r\n <vector-calendar-field\r\n *ngIf=\"field.type === fieldTypes.DATE\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [isRequired]=\"field.required\"\r\n [label]=\"field.placeholder || ''\"\r\n ></vector-calendar-field>\r\n </div>\r\n <div class=\"search-button col-12 sm:col-4 md:col-2\">\r\n <vector-button label=\"Pesquisar\" (click)=\"search()\" [disabled]=\"!formGroup.valid\"></vector-button>\r\n </div>\r\n</section>\r\n", styles: [".filter-container{align-items:center}.filter-container .field{display:flex;flex-direction:column}@media (min-width: 768px){.filter-container .search-button{padding-top:32px}}\n"], components: [{ type: i1.TextFieldComponent, selector: "vector-text-field", inputs: ["isRequired", "label", "maxlength", "isPassword", "numeric", "onlyText", "mask", "autoClear", "rightIcon", "centered", "enableDocumentTypeChoice", "control"], outputs: ["blurEvent", "enterKeyPress", "focusEvent", "onDocumentTypeChange"] }, { type: i2.DropdownFieldComponent, selector: "vector-dropdown-field", inputs: ["options", "isRequired", "control", "label", "service", "paged", "buttonAction", "dependencies"], outputs: ["onFocus"] }, { type: i3.CurrencyFieldComponent, selector: "vector-currency-field", inputs: ["control", "outlined"] }, { type: i4.CalendarComponent, selector: "vector-calendar-field", inputs: ["isRequired", "control", "label", "showCalendarOnFocus", "min", "max", "disabledDates", "disabled"] }, { type: i5.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "noShadow"], outputs: ["onClick"] }], directives: [{ type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "notHidden": i7.NotHiddenPipe } });
|
|
119
|
+
FiltersComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: FiltersComponent, selector: "vector-filters", inputs: { fields: "fields" }, outputs: { onSearch: "onSearch" }, ngImport: i0, template: "<section class=\"grid filter-container\" [hidden]=\"!fields?.length\">\r\n <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n <label>{{ field.label }}</label>\r\n <vector-text-field\r\n *ngIf=\"isTextFieldType(field)\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [mask]=\"field.mask\"\r\n [label]=\"field.placeholder\"\r\n [isRequired]=\"field.required\"\r\n [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n ></vector-text-field>\r\n <vector-dropdown-field\r\n *ngIf=\"field.type === fieldTypes.DROPDOWN\"\r\n [options]=\"field.options || []\"\r\n [service]=\"field.service\"\r\n [isRequired]=\"field.required\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [paged]=\"false\"\r\n [dependencies]=\"getFieldDependencies(field)\"\r\n ></vector-dropdown-field>\r\n <vector-currency-field\r\n *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [outlined]=\"true\"\r\n ></vector-currency-field>\r\n <vector-calendar-field\r\n *ngIf=\"field.type === fieldTypes.DATE\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [isRequired]=\"field.required\"\r\n [label]=\"field.placeholder || ''\"\r\n ></vector-calendar-field>\r\n </div>\r\n <div class=\"search-button col-12 sm:col-4 md:col-2\">\r\n <vector-button label=\"Pesquisar\" (click)=\"search()\" [disabled]=\"!formGroup.valid\"></vector-button>\r\n </div>\r\n</section>\r\n", styles: [".filter-container{align-items:center}.filter-container .field{display:flex;flex-direction:column}@media (min-width: 768px){.filter-container .search-button{padding-top:32px}}\n"], components: [{ type: i1.TextFieldComponent, selector: "vector-text-field", inputs: ["isRequired", "label", "maxlength", "isPassword", "numeric", "onlyText", "mask", "autoClear", "rightIcon", "centered", "enableDocumentTypeChoice", "control"], outputs: ["blurEvent", "enterKeyPress", "focusEvent", "onDocumentTypeChange"] }, { type: i2.DropdownFieldComponent, selector: "vector-dropdown-field", inputs: ["options", "isRequired", "control", "label", "service", "paged", "buttonAction", "dependencies"], outputs: ["onFocus"] }, { type: i3.CurrencyFieldComponent, selector: "vector-currency-field", inputs: ["minValue", "maxValue", "placeholder", "control", "outlined"] }, { type: i4.CalendarComponent, selector: "vector-calendar-field", inputs: ["isRequired", "control", "label", "showCalendarOnFocus", "min", "max", "disabledDates", "disabled"] }, { type: i5.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "noShadow"], outputs: ["onClick"] }], directives: [{ type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "notHidden": i7.NotHiddenPipe } });
|
|
120
120
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FiltersComponent, decorators: [{
|
|
121
121
|
type: Component,
|
|
122
122
|
args: [{ selector: 'vector-filters', template: "<section class=\"grid filter-container\" [hidden]=\"!fields?.length\">\r\n <div *ngFor=\"let field of fields | notHidden\" class=\"field col-12 sm:col-8 {{ getGridClass(field) }}\">\r\n <label>{{ field.label }}</label>\r\n <vector-text-field\r\n *ngIf=\"isTextFieldType(field)\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [mask]=\"field.mask\"\r\n [label]=\"field.placeholder\"\r\n [isRequired]=\"field.required\"\r\n [numeric]=\"field.type === fieldTypes.NUMBER\"\r\n ></vector-text-field>\r\n <vector-dropdown-field\r\n *ngIf=\"field.type === fieldTypes.DROPDOWN\"\r\n [options]=\"field.options || []\"\r\n [service]=\"field.service\"\r\n [isRequired]=\"field.required\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [paged]=\"false\"\r\n [dependencies]=\"getFieldDependencies(field)\"\r\n ></vector-dropdown-field>\r\n <vector-currency-field\r\n *ngIf=\"field.type === fieldTypes.CURRENCY\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [outlined]=\"true\"\r\n ></vector-currency-field>\r\n <vector-calendar-field\r\n *ngIf=\"field.type === fieldTypes.DATE\"\r\n [control]=\"formGroup.get(field.name)\"\r\n [isRequired]=\"field.required\"\r\n [label]=\"field.placeholder || ''\"\r\n ></vector-calendar-field>\r\n </div>\r\n <div class=\"search-button col-12 sm:col-4 md:col-2\">\r\n <vector-button label=\"Pesquisar\" (click)=\"search()\" [disabled]=\"!formGroup.valid\"></vector-button>\r\n </div>\r\n</section>\r\n", styles: [".filter-container{align-items:center}.filter-container .field{display:flex;flex-direction:column}@media (min-width: 768px){.filter-container .search-button{padding-top:32px}}\n"] }]
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import { map } from 'rxjs/operators';
|
|
3
|
+
import { Role } from '../models';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../services";
|
|
6
|
+
import * as i2 from "@angular/router";
|
|
7
|
+
import * as i3 from "../models";
|
|
8
|
+
export class GetTokenByGuidGuard {
|
|
9
|
+
constructor(authService, storageService, router, appName) {
|
|
10
|
+
this.authService = authService;
|
|
11
|
+
this.storageService = storageService;
|
|
12
|
+
this.router = router;
|
|
13
|
+
this.appName = appName;
|
|
14
|
+
}
|
|
15
|
+
canActivate(route) {
|
|
16
|
+
const paramTokenGuid = route.queryParams['Token'];
|
|
17
|
+
const role = atob(route.queryParams['role'] || '');
|
|
18
|
+
this.authService.role$.next(role);
|
|
19
|
+
if (paramTokenGuid) {
|
|
20
|
+
this.storageService.clear();
|
|
21
|
+
this.storageService.setRole(route.queryParams['role']);
|
|
22
|
+
this.storageService.setUserId(route.queryParams['userId']);
|
|
23
|
+
return this.authService.getTokenByGuid(paramTokenGuid).pipe(map((token) => {
|
|
24
|
+
if (token && role !== Role.ADMIN) {
|
|
25
|
+
return this.router.createUrlTree([this.appName.toLowerCase()]);
|
|
26
|
+
}
|
|
27
|
+
return true;
|
|
28
|
+
}));
|
|
29
|
+
}
|
|
30
|
+
else if (this.storageService.getToken()) {
|
|
31
|
+
if (role !== Role.ADMIN) {
|
|
32
|
+
return this.router.createUrlTree([this.appName.toLowerCase()]);
|
|
33
|
+
}
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
this.authService.logout();
|
|
37
|
+
return false;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
GetTokenByGuidGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: GetTokenByGuidGuard, deps: [{ token: i1.AuthService }, { token: i1.StorageService }, { token: i2.Router }, { token: 'appName' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
41
|
+
GetTokenByGuidGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: GetTokenByGuidGuard });
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: GetTokenByGuidGuard, decorators: [{
|
|
43
|
+
type: Injectable
|
|
44
|
+
}], ctorParameters: function () { return [{ type: i1.AuthService }, { type: i1.StorageService }, { type: i2.Router }, { type: i3.AppName, decorators: [{
|
|
45
|
+
type: Inject,
|
|
46
|
+
args: ['appName']
|
|
47
|
+
}] }]; } });
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LXRva2VuLWJ5LWd1aWQuZ3VhcmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmVjdG9yLWNvbXBvbmVudHMvc3JjL2xpYi9ndWFyZHMvZ2V0LXRva2VuLWJ5LWd1aWQuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkQsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JDLE9BQU8sRUFBVyxJQUFJLEVBQUUsTUFBTSxXQUFXLENBQUM7Ozs7O0FBSTFDLE1BQU0sT0FBTyxtQkFBbUI7SUFDOUIsWUFDVSxXQUF3QixFQUN4QixjQUE4QixFQUM5QixNQUFjLEVBQ0ssT0FBZ0I7UUFIbkMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDeEIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLFdBQU0sR0FBTixNQUFNLENBQVE7UUFDSyxZQUFPLEdBQVAsT0FBTyxDQUFTO0lBQzFDLENBQUM7SUFFSixXQUFXLENBQUMsS0FBNkI7UUFDdkMsTUFBTSxjQUFjLEdBQUcsS0FBSyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNsRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQVMsQ0FBQztRQUMzRCxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbEMsSUFBSSxjQUFjLEVBQUU7WUFDbEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUM1QixJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7WUFDdkQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1lBQzNELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUMsY0FBYyxDQUFDLENBQUMsSUFBSSxDQUN6RCxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtnQkFDWixJQUFJLEtBQUssSUFBSSxJQUFJLEtBQUssSUFBSSxDQUFDLEtBQUssRUFBRTtvQkFDaEMsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDO2lCQUNoRTtnQkFDRCxPQUFPLElBQUksQ0FBQztZQUNkLENBQUMsQ0FBQyxDQUNILENBQUM7U0FDSDthQUFNLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUN6QyxJQUFJLElBQUksS0FBSyxJQUFJLENBQUMsS0FBSyxFQUFFO2dCQUN2QixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUM7YUFDaEU7WUFDRCxPQUFPLElBQUksQ0FBQztTQUNiO1FBQ0QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUMxQixPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7O2dIQWhDVSxtQkFBbUIsaUdBS3BCLFNBQVM7b0hBTFIsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBRC9CLFVBQVU7OzBCQU1OLE1BQU07MkJBQUMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBDYW5BY3RpdmF0ZSwgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBBcHBOYW1lLCBSb2xlIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuaW1wb3J0IHsgQXV0aFNlcnZpY2UsIFN0b3JhZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgR2V0VG9rZW5CeUd1aWRHdWFyZCBpbXBsZW1lbnRzIENhbkFjdGl2YXRlIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBzdG9yYWdlU2VydmljZTogU3RvcmFnZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyLFxyXG4gICAgQEluamVjdCgnYXBwTmFtZScpIHByaXZhdGUgYXBwTmFtZTogQXBwTmFtZVxyXG4gICkge31cclxuXHJcbiAgY2FuQWN0aXZhdGUocm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QpIHtcclxuICAgIGNvbnN0IHBhcmFtVG9rZW5HdWlkID0gcm91dGUucXVlcnlQYXJhbXNbJ1Rva2VuJ107XHJcbiAgICBjb25zdCByb2xlID0gYXRvYihyb3V0ZS5xdWVyeVBhcmFtc1sncm9sZSddIHx8ICcnKSBhcyBSb2xlO1xyXG4gICAgdGhpcy5hdXRoU2VydmljZS5yb2xlJC5uZXh0KHJvbGUpO1xyXG4gICAgaWYgKHBhcmFtVG9rZW5HdWlkKSB7XHJcbiAgICAgIHRoaXMuc3RvcmFnZVNlcnZpY2UuY2xlYXIoKTtcclxuICAgICAgdGhpcy5zdG9yYWdlU2VydmljZS5zZXRSb2xlKHJvdXRlLnF1ZXJ5UGFyYW1zWydyb2xlJ10pO1xyXG4gICAgICB0aGlzLnN0b3JhZ2VTZXJ2aWNlLnNldFVzZXJJZChyb3V0ZS5xdWVyeVBhcmFtc1sndXNlcklkJ10pO1xyXG4gICAgICByZXR1cm4gdGhpcy5hdXRoU2VydmljZS5nZXRUb2tlbkJ5R3VpZChwYXJhbVRva2VuR3VpZCkucGlwZShcclxuICAgICAgICBtYXAoKHRva2VuKSA9PiB7XHJcbiAgICAgICAgICBpZiAodG9rZW4gJiYgcm9sZSAhPT0gUm9sZS5BRE1JTikge1xyXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5yb3V0ZXIuY3JlYXRlVXJsVHJlZShbdGhpcy5hcHBOYW1lLnRvTG93ZXJDYXNlKCldKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgICAgIH0pXHJcbiAgICAgICk7XHJcbiAgICB9IGVsc2UgaWYgKHRoaXMuc3RvcmFnZVNlcnZpY2UuZ2V0VG9rZW4oKSkge1xyXG4gICAgICBpZiAocm9sZSAhPT0gUm9sZS5BRE1JTikge1xyXG4gICAgICAgIHJldHVybiB0aGlzLnJvdXRlci5jcmVhdGVVcmxUcmVlKFt0aGlzLmFwcE5hbWUudG9Mb3dlckNhc2UoKV0pO1xyXG4gICAgICB9XHJcbiAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgfVxyXG4gICAgdGhpcy5hdXRoU2VydmljZS5sb2dvdXQoKTtcclxuICAgIHJldHVybiBmYWxzZTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../services";
|
|
4
|
+
import * as i2 from "@angular/router";
|
|
5
|
+
import * as i3 from "../models";
|
|
6
|
+
export class HasPermissionGuard {
|
|
7
|
+
constructor(profileService, router, appName) {
|
|
8
|
+
this.profileService = profileService;
|
|
9
|
+
this.router = router;
|
|
10
|
+
this.appName = appName;
|
|
11
|
+
}
|
|
12
|
+
canActivate(routeSnapshot) {
|
|
13
|
+
if (!this.profileService.userHasPermission(routeSnapshot.data['permission'])) {
|
|
14
|
+
return this.router.createUrlTree([this.appName.toLowerCase()]);
|
|
15
|
+
}
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
HasPermissionGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: HasPermissionGuard, deps: [{ token: i1.ProfileService }, { token: i2.Router }, { token: 'appName' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
20
|
+
HasPermissionGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: HasPermissionGuard });
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: HasPermissionGuard, decorators: [{
|
|
22
|
+
type: Injectable
|
|
23
|
+
}], ctorParameters: function () { return [{ type: i1.ProfileService }, { type: i2.Router }, { type: i3.AppName, decorators: [{
|
|
24
|
+
type: Inject,
|
|
25
|
+
args: ['appName']
|
|
26
|
+
}] }]; } });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFzLXBlcm1pc3Npb24uZ3VhcmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmVjdG9yLWNvbXBvbmVudHMvc3JjL2xpYi9ndWFyZHMvaGFzLXBlcm1pc3Npb24uZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBTW5ELE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsWUFDVSxjQUE4QixFQUM5QixNQUFjLEVBQ0ssT0FBZ0I7UUFGbkMsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLFdBQU0sR0FBTixNQUFNLENBQVE7UUFDSyxZQUFPLEdBQVAsT0FBTyxDQUFTO0lBQzFDLENBQUM7SUFFSixXQUFXLENBQUMsYUFBcUM7UUFDL0MsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxFQUFFO1lBQzVFLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztTQUNoRTtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzs7K0dBWlUsa0JBQWtCLHNFQUluQixTQUFTO21IQUpSLGtCQUFrQjsyRkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVOzswQkFLTixNQUFNOzJCQUFDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgQ2FuQWN0aXZhdGUsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IEFwcE5hbWUgfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBQcm9maWxlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEhhc1Blcm1pc3Npb25HdWFyZCBpbXBsZW1lbnRzIENhbkFjdGl2YXRlIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcHJvZmlsZVNlcnZpY2U6IFByb2ZpbGVTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlcixcclxuICAgIEBJbmplY3QoJ2FwcE5hbWUnKSBwcml2YXRlIGFwcE5hbWU6IEFwcE5hbWVcclxuICApIHt9XHJcblxyXG4gIGNhbkFjdGl2YXRlKHJvdXRlU25hcHNob3Q6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QpIHtcclxuICAgIGlmICghdGhpcy5wcm9maWxlU2VydmljZS51c2VySGFzUGVybWlzc2lvbihyb3V0ZVNuYXBzaG90LmRhdGFbJ3Blcm1pc3Npb24nXSkpIHtcclxuICAgICAgcmV0dXJuIHRoaXMucm91dGVyLmNyZWF0ZVVybFRyZWUoW3RoaXMuYXBwTmFtZS50b0xvd2VyQ2FzZSgpXSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './get-token-by-guid.guard';
|
|
2
|
+
export * from './has-permission.guard';
|
|
3
|
+
export * from './role.guard';
|
|
4
|
+
export * from './token-is-present.guard';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmVjdG9yLWNvbXBvbmVudHMvc3JjL2xpYi9ndWFyZHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2dldC10b2tlbi1ieS1ndWlkLmd1YXJkJztcclxuZXhwb3J0ICogZnJvbSAnLi9oYXMtcGVybWlzc2lvbi5ndWFyZCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcm9sZS5ndWFyZCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdG9rZW4taXMtcHJlc2VudC5ndWFyZCc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { Role } from '../models';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../services";
|
|
5
|
+
import * as i2 from "@angular/router";
|
|
6
|
+
export class RoleGuard {
|
|
7
|
+
constructor(storageService, router) {
|
|
8
|
+
this.storageService = storageService;
|
|
9
|
+
this.router = router;
|
|
10
|
+
}
|
|
11
|
+
canActivate(routeSnapshot) {
|
|
12
|
+
const isRoleAdmin = this.storageService.getRole() === Role.ADMIN;
|
|
13
|
+
if ((routeSnapshot.data['adminView'] && isRoleAdmin) || (!routeSnapshot.data['adminView'] && !isRoleAdmin)) {
|
|
14
|
+
return true;
|
|
15
|
+
}
|
|
16
|
+
return this.router.createUrlTree(['']);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
RoleGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: RoleGuard, deps: [{ token: i1.StorageService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
20
|
+
RoleGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: RoleGuard });
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: RoleGuard, decorators: [{
|
|
22
|
+
type: Injectable
|
|
23
|
+
}], ctorParameters: function () { return [{ type: i1.StorageService }, { type: i2.Router }]; } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9sZS5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL2d1YXJkcy9yb2xlLmd1YXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLFdBQVcsQ0FBQzs7OztBQUlqQyxNQUFNLE9BQU8sU0FBUztJQUNwQixZQUFvQixjQUE4QixFQUFVLE1BQWM7UUFBdEQsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQVUsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUFHLENBQUM7SUFFOUUsV0FBVyxDQUFDLGFBQXFDO1FBQy9DLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQztRQUNqRSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUFFO1lBQzFHLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFDRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN6QyxDQUFDOztzR0FUVSxTQUFTOzBHQUFULFNBQVM7MkZBQVQsU0FBUztrQkFEckIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgQ2FuQWN0aXZhdGUsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IFJvbGUgfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBTdG9yYWdlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIFJvbGVHdWFyZCBpbXBsZW1lbnRzIENhbkFjdGl2YXRlIHtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHN0b3JhZ2VTZXJ2aWNlOiBTdG9yYWdlU2VydmljZSwgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlcikge31cclxuXHJcbiAgY2FuQWN0aXZhdGUocm91dGVTbmFwc2hvdDogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCkge1xyXG4gICAgY29uc3QgaXNSb2xlQWRtaW4gPSB0aGlzLnN0b3JhZ2VTZXJ2aWNlLmdldFJvbGUoKSA9PT0gUm9sZS5BRE1JTjtcclxuICAgIGlmICgocm91dGVTbmFwc2hvdC5kYXRhWydhZG1pblZpZXcnXSAmJiBpc1JvbGVBZG1pbikgfHwgKCFyb3V0ZVNuYXBzaG90LmRhdGFbJ2FkbWluVmlldyddICYmICFpc1JvbGVBZG1pbikpIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdGhpcy5yb3V0ZXIuY3JlYXRlVXJsVHJlZShbJyddKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../services";
|
|
4
|
+
export class TokenIsPresentGuard {
|
|
5
|
+
constructor(storageService) {
|
|
6
|
+
this.storageService = storageService;
|
|
7
|
+
}
|
|
8
|
+
canActivate() {
|
|
9
|
+
return !!this.storageService.getToken();
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
TokenIsPresentGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: TokenIsPresentGuard, deps: [{ token: i1.StorageService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
13
|
+
TokenIsPresentGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: TokenIsPresentGuard });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: TokenIsPresentGuard, decorators: [{
|
|
15
|
+
type: Injectable
|
|
16
|
+
}], ctorParameters: function () { return [{ type: i1.StorageService }]; } });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW4taXMtcHJlc2VudC5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL2d1YXJkcy90b2tlbi1pcy1wcmVzZW50Lmd1YXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUszQyxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFlBQW9CLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtJQUFHLENBQUM7SUFFdEQsV0FBVztRQUNULE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDMUMsQ0FBQzs7Z0hBTFUsbUJBQW1CO29IQUFuQixtQkFBbUI7MkZBQW5CLG1CQUFtQjtrQkFEL0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2FuQWN0aXZhdGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBTdG9yYWdlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIFRva2VuSXNQcmVzZW50R3VhcmQgaW1wbGVtZW50cyBDYW5BY3RpdmF0ZSB7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yYWdlU2VydmljZTogU3RvcmFnZVNlcnZpY2UpIHt9XHJcblxyXG4gIGNhbkFjdGl2YXRlKCkge1xyXG4gICAgcmV0dXJuICEhdGhpcy5zdG9yYWdlU2VydmljZS5nZXRUb2tlbigpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1yZXNwb25zZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL21vZGVscy9odHRwLXJlc3BvbnNlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBIdHRwUmVzcG9uc2U8VD4gPSB7XHJcbiAgc3VjY2VzczogYm9vbGVhbjtcclxuICBzdGF0dXNDb2RlOiBudW1iZXI7XHJcbiAgZGF0YTogVDtcclxuICBtZXNzYWdlczogYW55W107XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBIdHRwUmVzcG9uc2VQYWdlZDxUPiA9IHtcclxuICBkYXRhOiBUW107XHJcbiAgcGFnZTogbnVtYmVyO1xyXG4gIHRvdGFsQ291bnQ6IG51bWJlcjtcclxuICB0b3RhbFBhZ2VzOiBudW1iZXI7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBIdHRwUmVzcG9uc2VHcmlkUGFnZWQ8VD4gPSB7XHJcbiAgZGF0YTogVFtdO1xyXG4gIGRyYXc6IG51bWJlcjtcclxuICByZWNvcmRzRmlsdGVyZWQ6IG51bWJlcjtcclxuICByZWNvcmRzVG90YWw6IG51bWJlcjtcclxufTtcclxuXHJcbmV4cG9ydCB0eXBlIEh0dHBMZWdhY3lMaXN0SXRlbSA9IHtcclxuICB0ZXh0OiBzdHJpbmc7XHJcbiAgdmFsdWU6IG51bWJlcjtcclxufTtcclxuXHJcbmV4cG9ydCB0eXBlIEh0dHBMZWdhY3lJdGVtRGF0YTxUPiA9IHtcclxuICBkOiBUO1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgSHR0cExlZ2FjeUNydWRBY3Rpb25SZXNwb25zZSA9IHtcclxuICBkaXNwbGF5TXNnOiBib29sZWFuO1xyXG4gIGVycm9yQ29kZTogbnVtYmVyO1xyXG4gIG1zZ0NvZGU6IG51bWJlcjtcclxuICBvazogYm9vbGVhbjtcclxuICByZXN1bHQ6IG51bWJlcjtcclxufTtcclxuIl19
|
|
@@ -15,7 +15,7 @@ export class AuthService {
|
|
|
15
15
|
this.baseUrl = 'Auth';
|
|
16
16
|
}
|
|
17
17
|
getTokenByGuid(tokenGuid) {
|
|
18
|
-
return this.http.get(
|
|
18
|
+
return this.http.get(`${this.baseUrl}/TemporaryAccessToken/${tokenGuid}`).pipe(tap((response) => {
|
|
19
19
|
this.storageService.setToken(response.accessToken);
|
|
20
20
|
this.storageService.setUsername(response.userName);
|
|
21
21
|
this.storageService.setRefreshToken(response.refreshToken);
|
|
@@ -56,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
56
56
|
type: Inject,
|
|
57
57
|
args: ['environment']
|
|
58
58
|
}] }]; } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvc2VydmljZXMvYXV0aC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZUFBZSxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFLMUMsTUFBTSxPQUFPLFdBQVc7SUFHdEIsWUFDVSxJQUFnQixFQUNoQixjQUE4QixFQUM5QixjQUE4QixFQUNQLFdBQWdCO1FBSHZDLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUNQLGdCQUFXLEdBQVgsV0FBVyxDQUFLO1FBTmpDLFVBQUssR0FBRyxJQUFJLGVBQWUsQ0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEUsWUFBTyxHQUFHLE1BQU0sQ0FBQztJQU0vQixDQUFDO0lBRUcsY0FBYyxDQUFDLFNBQWlCO1FBQ3JDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQU0sR0FBRyxJQUFJLENBQUMsT0FBTyx5QkFBeUIsU0FBUyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQ2pGLEdBQUcsQ0FBQyxDQUFDLFFBQWEsRUFBRSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUNuRCxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDbkQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO1lBQzNELElBQUksQ0FBQyxjQUFjLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdkMsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFFTSxzQkFBc0IsQ0FBQyxZQUFvQjtRQUNoRCxNQUFNLE9BQU8sR0FBRyxJQUFJLFdBQVcsRUFBRTthQUM5QixHQUFHLENBQUMsY0FBYyxFQUFFLG1DQUFtQyxDQUFDO2FBQ3hELEdBQUcsQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDN0IsT0FBTyxJQUFJLENBQUMsSUFBSTthQUNiLElBQUksQ0FDSCxlQUFlLEVBQ2YsWUFBWSxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsRUFBRSwyQ0FBMkMsWUFBWSxFQUFFLEVBQ3RHLEVBQUUsT0FBTyxFQUFFLENBQ1o7YUFDQSxJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDZixJQUFJLFFBQVEsRUFBRSxZQUFZLElBQUksUUFBUSxFQUFFLGFBQWEsRUFBRTtnQkFDckQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsVUFBVSxRQUFRLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQztnQkFDaEUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO2FBQzdEO1FBQ0gsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNOLENBQUM7SUFFTSxpQkFBaUI7UUFDdEIsT0FBTyxJQUFJLENBQUMsSUFBSTthQUNiLElBQUksQ0FBTSxPQUFPLElBQUksQ0FBQyxPQUFPLGdDQUFnQyxFQUFFO1lBQzlELFlBQVksRUFBRSxJQUFJLENBQUMsY0FBYyxDQUFDLGVBQWUsRUFBRTtTQUNwRCxDQUFDO2FBQ0QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsUUFBUSxFQUFFLFdBQVcsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFTSxNQUFNO1FBQ1gsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUM1QixNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQztJQUNyRCxDQUFDOzt3R0FwRFUsV0FBVyx3R0FPWixhQUFhOzRHQVBaLFdBQVcsY0FERSxNQUFNOzJGQUNuQixXQUFXO2tCQUR2QixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRTs7MEJBUTdCLE1BQU07MkJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQsIEh0dHBIZWFkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IG1hcCwgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBQcm9maWxlU2VydmljZSwgU3RvcmFnZVNlcnZpY2UgfSBmcm9tICcuJztcclxuaW1wb3J0IHsgUm9sZSB9IGZyb20gJy4uL21vZGVscyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxyXG5leHBvcnQgY2xhc3MgQXV0aFNlcnZpY2Uge1xyXG4gIHB1YmxpYyByZWFkb25seSByb2xlJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Um9sZT4odGhpcy5zdG9yYWdlU2VydmljZS5nZXRSb2xlKCkpO1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgYmFzZVVybCA9ICdBdXRoJztcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudCxcclxuICAgIHByaXZhdGUgc3RvcmFnZVNlcnZpY2U6IFN0b3JhZ2VTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBwcm9maWxlU2VydmljZTogUHJvZmlsZVNlcnZpY2UsXHJcbiAgICBASW5qZWN0KCdlbnZpcm9ubWVudCcpIHByaXZhdGUgZW52aXJvbm1lbnQ6IGFueVxyXG4gICkge31cclxuXHJcbiAgcHVibGljIGdldFRva2VuQnlHdWlkKHRva2VuR3VpZDogc3RyaW5nKTogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcclxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PGFueT4oYCR7dGhpcy5iYXNlVXJsfS9UZW1wb3JhcnlBY2Nlc3NUb2tlbi8ke3Rva2VuR3VpZH1gKS5waXBlKFxyXG4gICAgICB0YXAoKHJlc3BvbnNlOiBhbnkpID0+IHtcclxuICAgICAgICB0aGlzLnN0b3JhZ2VTZXJ2aWNlLnNldFRva2VuKHJlc3BvbnNlLmFjY2Vzc1Rva2VuKTtcclxuICAgICAgICB0aGlzLnN0b3JhZ2VTZXJ2aWNlLnNldFVzZXJuYW1lKHJlc3BvbnNlLnVzZXJOYW1lKTtcclxuICAgICAgICB0aGlzLnN0b3JhZ2VTZXJ2aWNlLnNldFJlZnJlc2hUb2tlbihyZXNwb25zZS5yZWZyZXNoVG9rZW4pO1xyXG4gICAgICAgIHRoaXMucHJvZmlsZVNlcnZpY2UuZ2V0VXNlclByb2ZpbGUoKTtcclxuICAgICAgfSlcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0VG9rZW5CeVJlZnJlc2hUb2tlbihyZWZyZXNoVG9rZW46IHN0cmluZykge1xyXG4gICAgY29uc3QgaGVhZGVycyA9IG5ldyBIdHRwSGVhZGVycygpXHJcbiAgICAgIC5zZXQoJ0NvbnRlbnQtVHlwZScsICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnKVxyXG4gICAgICAuc2V0KCduby1zcGlubmVyJywgJ3RydWUnKTtcclxuICAgIHJldHVybiB0aGlzLmh0dHBcclxuICAgICAgLnBvc3Q8YW55PihcclxuICAgICAgICBgY29ubmVjdC90b2tlbmAsXHJcbiAgICAgICAgYHVzZXJuYW1lPSR7dGhpcy5zdG9yYWdlU2VydmljZS5nZXRVc2VybmFtZSgpfSZncmFudF90eXBlPXJlZnJlc2hfdG9rZW4mcmVmcmVzaF90b2tlbj0ke3JlZnJlc2hUb2tlbn1gLFxyXG4gICAgICAgIHsgaGVhZGVycyB9XHJcbiAgICAgIClcclxuICAgICAgLnBpcGUoXHJcbiAgICAgICAgdGFwKChyZXNwb25zZSkgPT4ge1xyXG4gICAgICAgICAgaWYgKHJlc3BvbnNlPy5hY2Nlc3NfdG9rZW4gJiYgcmVzcG9uc2U/LnJlZnJlc2hfdG9rZW4pIHtcclxuICAgICAgICAgICAgdGhpcy5zdG9yYWdlU2VydmljZS5zZXRUb2tlbihgQmVhcmVyICR7cmVzcG9uc2UuYWNjZXNzX3Rva2VufWApO1xyXG4gICAgICAgICAgICB0aGlzLnN0b3JhZ2VTZXJ2aWNlLnNldFJlZnJlc2hUb2tlbihyZXNwb25zZS5yZWZyZXNoX3Rva2VuKTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KVxyXG4gICAgICApO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdlbmVyYXRlVG9rZW5HdWlkKCk6IE9ic2VydmFibGU8c3RyaW5nPiB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwXHJcbiAgICAgIC5wb3N0PGFueT4oYGFwaS8ke3RoaXMuYmFzZVVybH0vVGVtcG9yYXJ5QWNjZXNzVG9rZW4vZ2VuZXJhdGVgLCB7XHJcbiAgICAgICAgUmVmcmVzaFRva2VuOiB0aGlzLnN0b3JhZ2VTZXJ2aWNlLmdldFJlZnJlc2hUb2tlbigpLFxyXG4gICAgICB9KVxyXG4gICAgICAucGlwZShtYXAoKHJlc3BvbnNlKSA9PiByZXNwb25zZT8uYWNjZXNzVG9rZW4gfHwgJycpKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBsb2dvdXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLnN0b3JhZ2VTZXJ2aWNlLmNsZWFyKCk7XHJcbiAgICB3aW5kb3cubG9jYXRpb24uaHJlZiA9IHRoaXMuZW52aXJvbm1lbnQuUE9SVEFMX1VSTDtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -10,10 +10,16 @@ export class StorageService {
|
|
|
10
10
|
sessionStorage.clear();
|
|
11
11
|
}
|
|
12
12
|
get(key) {
|
|
13
|
-
|
|
13
|
+
const storageItem = localStorage.getItem(key);
|
|
14
|
+
try {
|
|
15
|
+
return storageItem ? JSON.parse(storageItem) : '';
|
|
16
|
+
}
|
|
17
|
+
catch (e) {
|
|
18
|
+
return storageItem;
|
|
19
|
+
}
|
|
14
20
|
}
|
|
15
21
|
set(key, value) {
|
|
16
|
-
localStorage.setItem(key, value);
|
|
22
|
+
localStorage.setItem(key, typeof value === 'string' ? value : JSON.stringify(value));
|
|
17
23
|
}
|
|
18
24
|
remove(key) {
|
|
19
25
|
localStorage.removeItem(key);
|
|
@@ -81,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
81
87
|
type: Injectable,
|
|
82
88
|
args: [{ providedIn: 'root' }]
|
|
83
89
|
}], ctorParameters: function () { return []; } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvc2VydmljZXMvc3RvcmFnZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSTNDLE1BQU0sT0FBTyxjQUFjO0lBQ3pCLGdCQUFlLENBQUM7SUFFVCxLQUFLO1FBQ1YsY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3ZCLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRU0sWUFBWTtRQUNqQixjQUFjLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVNLEdBQUcsQ0FBQyxHQUFXO1FBQ3BCLE1BQU0sV0FBVyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDOUMsSUFBSTtZQUNGLE9BQU8sV0FBVyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7U0FDbkQ7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLE9BQU8sV0FBVyxDQUFDO1NBQ3BCO0lBQ0gsQ0FBQztJQUVNLEdBQUcsQ0FBQyxHQUFXLEVBQUUsS0FBVTtRQUNoQyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxPQUFPLEtBQUssS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3ZGLENBQUM7SUFFTSxNQUFNLENBQUMsR0FBVztRQUN2QixZQUFZLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFTSxRQUFRO1FBQ2IsT0FBTyxZQUFZLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM3QyxDQUFDO0lBRU0sUUFBUSxDQUFDLEtBQWE7UUFDM0IsWUFBWSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVNLFdBQVc7UUFDaEIsWUFBWSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRU0sZUFBZTtRQUNwQixPQUFPLGNBQWMsQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RELENBQUM7SUFFTSxlQUFlLENBQUMsWUFBb0I7UUFDekMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxjQUFjLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVNLGtCQUFrQjtRQUN2QixjQUFjLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFTSxXQUFXO1FBQ2hCLE9BQU8sY0FBYyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDbEQsQ0FBQztJQUVNLFdBQVcsQ0FBQyxRQUFnQjtRQUNqQyxjQUFjLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxRQUFRLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRU0sY0FBYztRQUNuQixjQUFjLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFTSxTQUFTO1FBQ2QsTUFBTSxNQUFNLEdBQUcsY0FBYyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDdEQsT0FBTyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVNLFNBQVMsQ0FBQyxNQUFjO1FBQzdCLGNBQWMsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxHQUFHLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRU0sV0FBVztRQUNoQixjQUFjLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFTSxPQUFPO1FBQ1osT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQVMsQ0FBQztJQUM1RCxDQUFDO0lBRU0sT0FBTyxDQUFDLElBQWE7UUFDMUIsY0FBYyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFTSxTQUFTO1FBQ2QsY0FBYyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU0sVUFBVTtRQUtmLE1BQU0sSUFBSSxHQUFHLGNBQWMsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3JELE9BQU8sSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDeEMsQ0FBQztJQUVNLFVBQVUsQ0FBQyxRQUlqQjtRQUNDLGNBQWMsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUVNLGFBQWE7UUFDbEIsY0FBYyxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN2QyxDQUFDOzsyR0E3R1UsY0FBYzsrR0FBZCxjQUFjLGNBREQsTUFBTTsyRkFDbkIsY0FBYztrQkFEMUIsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFByb2ZpbGVNb2R1bGUsIFJvbGUgfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5cclxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcclxuZXhwb3J0IGNsYXNzIFN0b3JhZ2VTZXJ2aWNlIHtcclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcblxyXG4gIHB1YmxpYyBjbGVhcigpOiB2b2lkIHtcclxuICAgIHNlc3Npb25TdG9yYWdlLmNsZWFyKCk7XHJcbiAgICBsb2NhbFN0b3JhZ2UuY2xlYXIoKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBjbGVhclNlc3Npb24oKTogdm9pZCB7XHJcbiAgICBzZXNzaW9uU3RvcmFnZS5jbGVhcigpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldChrZXk6IHN0cmluZyk6IGFueSB7XHJcbiAgICBjb25zdCBzdG9yYWdlSXRlbSA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKGtleSk7XHJcbiAgICB0cnkge1xyXG4gICAgICByZXR1cm4gc3RvcmFnZUl0ZW0gPyBKU09OLnBhcnNlKHN0b3JhZ2VJdGVtKSA6ICcnO1xyXG4gICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICByZXR1cm4gc3RvcmFnZUl0ZW07XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0KGtleTogc3RyaW5nLCB2YWx1ZTogYW55KTogdm9pZCB7XHJcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbShrZXksIHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycgPyB2YWx1ZSA6IEpTT04uc3RyaW5naWZ5KHZhbHVlKSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgcmVtb3ZlKGtleTogc3RyaW5nKTogdm9pZCB7XHJcbiAgICBsb2NhbFN0b3JhZ2UucmVtb3ZlSXRlbShrZXkpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldFRva2VuKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gbG9jYWxTdG9yYWdlLmdldEl0ZW0oJ3Rva2VuJykgfHwgJyc7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0VG9rZW4odG9rZW46IHN0cmluZykge1xyXG4gICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oJ3Rva2VuJywgdG9rZW4pO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHJlbW92ZVRva2VuKCkge1xyXG4gICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oJ3Rva2VuJyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0UmVmcmVzaFRva2VuKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbSgncmVmcmVzaFRva2VuJykgfHwgJyc7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0UmVmcmVzaFRva2VuKHJlZnJlc2hUb2tlbjogc3RyaW5nKSB7XHJcbiAgICBzZXNzaW9uU3RvcmFnZS5zZXRJdGVtKCdyZWZyZXNoVG9rZW4nLCByZWZyZXNoVG9rZW4pO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHJlbW92ZVJlZnJlc2hUb2tlbigpIHtcclxuICAgIHNlc3Npb25TdG9yYWdlLnJlbW92ZUl0ZW0oJ3JlZnJlc2hUb2tlbicpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldFVzZXJuYW1lKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbSgndXNlcm5hbWUnKSB8fCAnJztcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzZXRVc2VybmFtZSh1c2VybmFtZTogc3RyaW5nKSB7XHJcbiAgICBzZXNzaW9uU3RvcmFnZS5zZXRJdGVtKCd1c2VybmFtZScsIHVzZXJuYW1lKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyByZW1vdmVVc2VybmFtZSgpIHtcclxuICAgIHNlc3Npb25TdG9yYWdlLnJlbW92ZUl0ZW0oJ3VzZXJuYW1lJyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0VXNlcklkKCk6IG51bWJlciB7XHJcbiAgICBjb25zdCB1c2VySWQgPSBzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKCd1c2VySWQnKSB8fCAnJztcclxuICAgIHJldHVybiB1c2VySWQgPyArYXRvYih1c2VySWQpIDogMDtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzZXRVc2VySWQodXNlcklkOiBudW1iZXIpIHtcclxuICAgIHNlc3Npb25TdG9yYWdlLnNldEl0ZW0oJ3VzZXJJZCcsIGJ0b2EoYCR7dXNlcklkfWApKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBjbGVhclVzZXJJZCgpIHtcclxuICAgIHNlc3Npb25TdG9yYWdlLnJlbW92ZUl0ZW0oJ3VzZXJJZCcpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldFJvbGUoKTogUm9sZSB7XHJcbiAgICByZXR1cm4gYXRvYihzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKCdyb2xlJykgfHwgJycpIGFzIFJvbGU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0Um9sZShyb2xlPzogc3RyaW5nKSB7XHJcbiAgICBzZXNzaW9uU3RvcmFnZS5zZXRJdGVtKCdyb2xlJywgcm9sZSB8fCAnJyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY2xlYXJSb2xlKCkge1xyXG4gICAgc2Vzc2lvblN0b3JhZ2UucmVtb3ZlSXRlbSgncm9sZScpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldFByb2ZpbGUoKToge1xyXG4gICAgbWFya2V0cGxhY2U6IFByb2ZpbGVNb2R1bGUgfCB1bmRlZmluZWQ7XHJcbiAgICBmaW50ZWNoOiBQcm9maWxlTW9kdWxlIHwgdW5kZWZpbmVkO1xyXG4gICAgYWxsTW9kdWxlczogUHJvZmlsZU1vZHVsZVtdIHwgdW5kZWZpbmVkO1xyXG4gIH0ge1xyXG4gICAgY29uc3QgZGF0YSA9IHNlc3Npb25TdG9yYWdlLmdldEl0ZW0oJ3Byb2ZpbGUnKSB8fCAnJztcclxuICAgIHJldHVybiBkYXRhID8gSlNPTi5wYXJzZShkYXRhKSA6IGRhdGE7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc2V0UHJvZmlsZShwcm9maWxlczoge1xyXG4gICAgbWFya2V0cGxhY2U6IFByb2ZpbGVNb2R1bGUgfCB1bmRlZmluZWQ7XHJcbiAgICBmaW50ZWNoOiBQcm9maWxlTW9kdWxlIHwgdW5kZWZpbmVkO1xyXG4gICAgYWxsTW9kdWxlczogUHJvZmlsZU1vZHVsZVtdIHwgdW5kZWZpbmVkO1xyXG4gIH0pIHtcclxuICAgIHNlc3Npb25TdG9yYWdlLnNldEl0ZW0oJ3Byb2ZpbGUnLCBKU09OLnN0cmluZ2lmeShwcm9maWxlcyB8fCAnJykpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHJlbW92ZVByb2ZpbGUoKSB7XHJcbiAgICBzZXNzaW9uU3RvcmFnZS5yZW1vdmVJdGVtKCdwcm9maWxlJyk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
const CPF_PATTERN = '###.###.###-##';
|
|
2
2
|
const CNPJ_PATTERN = '##.###.###/####-##';
|
|
3
3
|
const BOLETO_PATTERN = '#####.##### #####.###### #####.###### # ##############';
|
|
4
|
+
const POSTALCODE_TEXT_FIELD_PATTERN = '#####-###';
|
|
4
5
|
export class MaskUtil {
|
|
5
6
|
static formatDocument(stringValue) {
|
|
6
7
|
if (!stringValue) {
|
|
@@ -14,6 +15,9 @@ export class MaskUtil {
|
|
|
14
15
|
}
|
|
15
16
|
return stringValue;
|
|
16
17
|
}
|
|
18
|
+
static formatPostalCode(stringValue) {
|
|
19
|
+
return this.doMaskString(stringValue, POSTALCODE_TEXT_FIELD_PATTERN);
|
|
20
|
+
}
|
|
17
21
|
static formatBoleto(stringValue) {
|
|
18
22
|
return this.doMaskString(stringValue, BOLETO_PATTERN);
|
|
19
23
|
}
|
|
@@ -28,4 +32,4 @@ MaskUtil.BOLETO_TEXT_FIELD_PATTERN = '99999.99999 99999.999999 99999.999999 9 99
|
|
|
28
32
|
MaskUtil.CELLPHONE_TEXT_FIELD_PATTERN = '(99) 99999-9999';
|
|
29
33
|
MaskUtil.PHONE_TEXT_FIELD_PATTERN = '(99) 9999-9999';
|
|
30
34
|
MaskUtil.POSTALCODE_TEXT_FIELD_PATTERN = '99999-999';
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFzay51dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXZlY3Rvci1jb21wb25lbnRzL3NyYy9saWIvdXRpbHMvbWFzay51dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sV0FBVyxHQUFHLGdCQUFnQixDQUFDO0FBQ3JDLE1BQU0sWUFBWSxHQUFHLG9CQUFvQixDQUFDO0FBQzFDLE1BQU0sY0FBYyxHQUFHLHdEQUF3RCxDQUFDO0FBQ2hGLE1BQU0sNkJBQTZCLEdBQUcsV0FBVyxDQUFDO0FBRWxELE1BQU0sT0FBTyxRQUFRO0lBUVosTUFBTSxDQUFDLGNBQWMsQ0FBQyxXQUFtQjtRQUM5QyxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ2hCLE9BQU8sRUFBRSxDQUFDO1NBQ1g7UUFFRCxJQUFJLFdBQVcsQ0FBQyxNQUFNLEtBQUssRUFBRSxFQUFFO1lBQzdCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsV0FBVyxDQUFDLENBQUM7U0FDcEQ7UUFFRCxJQUFJLFdBQVcsQ0FBQyxNQUFNLEtBQUssRUFBRSxFQUFFO1lBQzdCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsWUFBWSxDQUFDLENBQUM7U0FDckQ7UUFFRCxPQUFPLFdBQVcsQ0FBQztJQUNyQixDQUFDO0lBRU0sTUFBTSxDQUFDLGdCQUFnQixDQUFDLFdBQW1CO1FBQ2hELE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsNkJBQTZCLENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBRU0sTUFBTSxDQUFDLFlBQVksQ0FBQyxXQUFtQjtRQUM1QyxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLGNBQWMsQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFTyxNQUFNLENBQUMsWUFBWSxDQUFDLEdBQVcsRUFBRSxPQUFlO1FBQ3RELElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNWLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUMvQyxDQUFDOztBQWxDYSwrQkFBc0IsR0FBRyxnQkFBZ0IsQ0FBQztBQUMxQyxnQ0FBdUIsR0FBRyxvQkFBb0IsQ0FBQztBQUMvQyxrQ0FBeUIsR0FBRyx3REFBd0QsQ0FBQztBQUNyRixxQ0FBNEIsR0FBRyxpQkFBaUIsQ0FBQztBQUNqRCxpQ0FBd0IsR0FBRyxnQkFBZ0IsQ0FBQztBQUM1QyxzQ0FBNkIsR0FBRyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBDUEZfUEFUVEVSTiA9ICcjIyMuIyMjLiMjIy0jIyc7XHJcbmNvbnN0IENOUEpfUEFUVEVSTiA9ICcjIy4jIyMuIyMjLyMjIyMtIyMnO1xyXG5jb25zdCBCT0xFVE9fUEFUVEVSTiA9ICcjIyMjIy4jIyMjIyAjIyMjIy4jIyMjIyMgIyMjIyMuIyMjIyMjICMgIyMjIyMjIyMjIyMjIyMnO1xyXG5jb25zdCBQT1NUQUxDT0RFX1RFWFRfRklFTERfUEFUVEVSTiA9ICcjIyMjIy0jIyMnO1xyXG5cclxuZXhwb3J0IGNsYXNzIE1hc2tVdGlsIHtcclxuICBwdWJsaWMgc3RhdGljIENQRl9URVhUX0ZJRUxEX1BBVFRFUk4gPSAnOTk5Ljk5OS45OTktOTknO1xyXG4gIHB1YmxpYyBzdGF0aWMgQ05QSl9URVhUX0ZJRUxEX1BBVFRFUk4gPSAnOTkuOTk5Ljk5OS85OTk5LTk5JztcclxuICBwdWJsaWMgc3RhdGljIEJPTEVUT19URVhUX0ZJRUxEX1BBVFRFUk4gPSAnOTk5OTkuOTk5OTkgOTk5OTkuOTk5OTk5IDk5OTk5Ljk5OTk5OSA5IDk5OTk5OTk5OTk5OTk5JztcclxuICBwdWJsaWMgc3RhdGljIENFTExQSE9ORV9URVhUX0ZJRUxEX1BBVFRFUk4gPSAnKDk5KSA5OTk5OS05OTk5JztcclxuICBwdWJsaWMgc3RhdGljIFBIT05FX1RFWFRfRklFTERfUEFUVEVSTiA9ICcoOTkpIDk5OTktOTk5OSc7XHJcbiAgcHVibGljIHN0YXRpYyBQT1NUQUxDT0RFX1RFWFRfRklFTERfUEFUVEVSTiA9ICc5OTk5OS05OTknO1xyXG5cclxuICBwdWJsaWMgc3RhdGljIGZvcm1hdERvY3VtZW50KHN0cmluZ1ZhbHVlOiBzdHJpbmcpIHtcclxuICAgIGlmICghc3RyaW5nVmFsdWUpIHtcclxuICAgICAgcmV0dXJuICcnO1xyXG4gICAgfVxyXG5cclxuICAgIGlmIChzdHJpbmdWYWx1ZS5sZW5ndGggPT09IDExKSB7XHJcbiAgICAgIHJldHVybiB0aGlzLmRvTWFza1N0cmluZyhzdHJpbmdWYWx1ZSwgQ1BGX1BBVFRFUk4pO1xyXG4gICAgfVxyXG5cclxuICAgIGlmIChzdHJpbmdWYWx1ZS5sZW5ndGggPT09IDE0KSB7XHJcbiAgICAgIHJldHVybiB0aGlzLmRvTWFza1N0cmluZyhzdHJpbmdWYWx1ZSwgQ05QSl9QQVRURVJOKTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gc3RyaW5nVmFsdWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc3RhdGljIGZvcm1hdFBvc3RhbENvZGUoc3RyaW5nVmFsdWU6IHN0cmluZykge1xyXG4gICAgcmV0dXJuIHRoaXMuZG9NYXNrU3RyaW5nKHN0cmluZ1ZhbHVlLCBQT1NUQUxDT0RFX1RFWFRfRklFTERfUEFUVEVSTik7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc3RhdGljIGZvcm1hdEJvbGV0byhzdHJpbmdWYWx1ZTogc3RyaW5nKSB7XHJcbiAgICByZXR1cm4gdGhpcy5kb01hc2tTdHJpbmcoc3RyaW5nVmFsdWUsIEJPTEVUT19QQVRURVJOKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgc3RhdGljIGRvTWFza1N0cmluZyhzdHI6IHN0cmluZywgcGF0dGVybjogc3RyaW5nKSB7XHJcbiAgICBsZXQgaSA9IDA7XHJcbiAgICByZXR1cm4gcGF0dGVybi5yZXBsYWNlKC8jL2csICgpID0+IHN0cltpKytdKTtcclxuICB9XHJcbn1cclxuIl19
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
export * from './lib/components';
|
|
2
|
+
export * from './lib/guards';
|
|
2
3
|
export * from './lib/interceptors';
|
|
3
4
|
export * from './lib/models';
|
|
4
5
|
export * from './lib/pipes';
|
|
5
6
|
export * from './lib/services';
|
|
6
7
|
export * from './lib/utils';
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ3VhcmRzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyY2VwdG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMnO1xuIl19
|