ngx-vector-components 0.0.4 → 0.0.7
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/fields.module.mjs +6 -2
- 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/interceptors/http-interceptor.mjs +12 -1
- package/esm2020/lib/models/http-response.model.mjs +1 -1
- package/esm2020/lib/services/auth.service.mjs +3 -1
- package/esm2020/lib/services/storage.service.mjs +19 -1
- package/esm2020/lib/shared/shared.module.mjs +4 -5
- package/esm2020/lib/utils/mask.util.mjs +5 -1
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/ngx-vector-components.mjs +213 -65
- package/fesm2015/ngx-vector-components.mjs.map +1 -1
- package/fesm2020/ngx-vector-components.mjs +203 -61
- 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/components/fields/fields.module.d.ts +2 -1
- 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/interceptors/http-interceptor.d.ts +2 -0
- package/lib/models/http-response.model.d.ts +1 -1
- package/lib/services/auth.service.d.ts +3 -1
- package/lib/services/storage.service.d.ts +4 -0
- package/lib/shared/shared.module.d.ts +2 -3
- 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"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
3
3
|
import { AutoCompleteModule } from 'primeng/autocomplete';
|
|
4
|
+
import { ButtonModule } from 'primeng/button';
|
|
4
5
|
import { CalendarModule } from 'primeng/calendar';
|
|
5
6
|
import { CheckboxModule } from 'primeng/checkbox';
|
|
6
7
|
import { DialogModule } from 'primeng/dialog';
|
|
@@ -66,7 +67,8 @@ FieldsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "
|
|
|
66
67
|
InputNumberModule,
|
|
67
68
|
MenuModule,
|
|
68
69
|
TabViewModule,
|
|
69
|
-
PanelModule
|
|
70
|
+
PanelModule,
|
|
71
|
+
ButtonModule], exports: [TextFieldComponent,
|
|
70
72
|
CheckboxFieldComponent,
|
|
71
73
|
ButtonComponent,
|
|
72
74
|
CalendarComponent,
|
|
@@ -102,6 +104,7 @@ FieldsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
|
102
104
|
MenuModule,
|
|
103
105
|
TabViewModule,
|
|
104
106
|
PanelModule,
|
|
107
|
+
ButtonModule,
|
|
105
108
|
], FileUploadModule,
|
|
106
109
|
DialogModule] });
|
|
107
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: FieldsModule, decorators: [{
|
|
@@ -128,6 +131,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
128
131
|
MenuModule,
|
|
129
132
|
TabViewModule,
|
|
130
133
|
PanelModule,
|
|
134
|
+
ButtonModule,
|
|
131
135
|
],
|
|
132
136
|
declarations: [
|
|
133
137
|
TextFieldComponent,
|
|
@@ -163,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
163
167
|
],
|
|
164
168
|
}]
|
|
165
169
|
}] });
|
|
166
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields.module.js","sourceRoot":"","sources":["../../../../../../projects/ngx-vector-components/src/lib/components/fields/fields.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { AutoCompleteModule } from 'primeng/autocomplete';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { CheckboxModule } from 'primeng/checkbox';\r\nimport { DialogModule } from 'primeng/dialog';\r\nimport { DropdownModule } from 'primeng/dropdown';\r\nimport { FileUploadModule } from 'primeng/fileupload';\r\nimport { InputMaskModule } from 'primeng/inputmask';\r\nimport { InputNumberModule } from 'primeng/inputnumber';\r\nimport { InputTextModule } from 'primeng/inputtext';\r\nimport { KeyFilterModule } from 'primeng/keyfilter';\r\nimport { MenuModule } from 'primeng/menu';\r\nimport { MultiSelectModule } from 'primeng/multiselect';\r\nimport { RadioButtonModule } from 'primeng/radiobutton';\r\nimport { SliderModule } from 'primeng/slider';\r\nimport { TableModule } from 'primeng/table';\r\nimport { TabViewModule } from 'primeng/tabview';\r\nimport { SharedModule } from '../../shared/shared.module';\r\nimport { PanelModule } from '../panel/panel.module';\r\nimport { ButtonComponent } from './button';\r\nimport { CalendarComponent } from './calendar-field';\r\nimport { CheckboxFieldComponent } from './checkbox-field';\r\nimport { CurrencyFieldComponent } from './currency-field';\r\nimport { DataTableComponent } from './data-table';\r\nimport { DropdownFieldComponent } from './dropdown-field';\r\nimport { FiltersComponent } from './filters';\r\nimport { MultiselectFieldComponent } from './multiselect-field';\r\nimport { PercentageFieldComponent } from './percentage-field';\r\nimport { RadioButtonFieldComponent } from './radio-button-field';\r\nimport { RangeValueComponent } from './range-value';\r\nimport { SearchFieldComponent } from './search-field';\r\nimport { TextFieldComponent } from './text-field';\r\n@NgModule({\r\n  imports: [\r\n    SharedModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    KeyFilterModule,\r\n    InputTextModule,\r\n    CheckboxModule,\r\n    InputMaskModule,\r\n    CalendarModule,\r\n    MultiSelectModule,\r\n    DropdownModule,\r\n    AutoCompleteModule,\r\n    SliderModule,\r\n    RadioButtonModule,\r\n    TableModule,\r\n    FileUploadModule,\r\n    DialogModule,\r\n    InputNumberModule,\r\n    MenuModule,\r\n    TabViewModule,\r\n    PanelModule,\r\n    ButtonModule,\r\n  ],\r\n  declarations: [\r\n    TextFieldComponent,\r\n    CheckboxFieldComponent,\r\n    ButtonComponent,\r\n    CalendarComponent,\r\n    MultiselectFieldComponent,\r\n    DropdownFieldComponent,\r\n    RangeValueComponent,\r\n    SearchFieldComponent,\r\n    RadioButtonFieldComponent,\r\n    CurrencyFieldComponent,\r\n    PercentageFieldComponent,\r\n    DataTableComponent,\r\n    FiltersComponent,\r\n  ],\r\n  exports: [\r\n    TextFieldComponent,\r\n    CheckboxFieldComponent,\r\n    ButtonComponent,\r\n    CalendarComponent,\r\n    MultiselectFieldComponent,\r\n    DropdownFieldComponent,\r\n    RangeValueComponent,\r\n    SearchFieldComponent,\r\n    RadioButtonFieldComponent,\r\n    FileUploadModule,\r\n    DialogModule,\r\n    CurrencyFieldComponent,\r\n    PercentageFieldComponent,\r\n    DataTableComponent,\r\n    FiltersComponent,\r\n  ],\r\n})\r\nexport class FieldsModule {}\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=
|
|
@@ -93,10 +93,21 @@ export class HttpInterceptorProvider {
|
|
|
93
93
|
return request.clone({ setHeaders: { contentType: 'application/json' } });
|
|
94
94
|
}
|
|
95
95
|
fixUrl(request) {
|
|
96
|
+
if (this.isAuthRequest(request.url) || this.isProfilesRequest(request.url)) {
|
|
97
|
+
return request.clone({
|
|
98
|
+
url: `${this.environment.API_URL.replace('/api', '')}/${request.url}`,
|
|
99
|
+
});
|
|
100
|
+
}
|
|
96
101
|
return request.clone({
|
|
97
102
|
url: request.url.startsWith('/assets/') ? request.url : `${this.environment.API_URL}/${request.url}`,
|
|
98
103
|
});
|
|
99
104
|
}
|
|
105
|
+
isAuthRequest(url) {
|
|
106
|
+
return url.includes('connect/token');
|
|
107
|
+
}
|
|
108
|
+
isProfilesRequest(url) {
|
|
109
|
+
return url.includes('connect/userinfo');
|
|
110
|
+
}
|
|
100
111
|
handle401Error(request, next) {
|
|
101
112
|
if (!this.isRefreshing) {
|
|
102
113
|
this.isRefreshing = true;
|
|
@@ -130,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
130
141
|
type: Inject,
|
|
131
142
|
args: ['environment']
|
|
132
143
|
}] }]; } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-interceptor.js","sourceRoot":"","sources":["../../../../../projects/ngx-vector-components/src/lib/interceptors/http-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  HttpErrorResponse,\r\n  HttpEvent,\r\n  HttpHandler,\r\n  HttpInterceptor,\r\n  HttpRequest,\r\n  HttpResponse,\r\n} from '@angular/common/http';\r\nimport { Inject, Injectable } from '@angular/core';\r\nimport { BehaviorSubject, Observable, throwError } from 'rxjs';\r\nimport { catchError, filter, switchMap, take, tap } from 'rxjs/operators';\r\nimport { AuthService, ErrorMessageService, LoadingService, StorageService } from '../services';\r\n\r\n@Injectable()\r\nexport class HttpInterceptorProvider implements HttpInterceptor {\r\n  private activeRequests: string[] = [];\r\n  private isRefreshing = false;\r\n  private refreshTokenSubject: BehaviorSubject<any> = new BehaviorSubject<any>(null);\r\n\r\n  constructor(\r\n    private storageService: StorageService,\r\n    private errorMessageService: ErrorMessageService,\r\n    private loadingService: LoadingService,\r\n    private authService: AuthService,\r\n    @Inject('environment') private environment: any\r\n  ) {}\r\n\r\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    if (!this.isRefreshTokenRequest(request.url)) {\r\n      request = this.addTokenIfPresent(request);\r\n      request = this.addModifierIdIfPresent(request);\r\n      request = this.addContentType(request);\r\n    }\r\n    request = this.fixUrl(request);\r\n\r\n    const noSpinnerHeader = request.headers.get('no-spinner');\r\n    if (!noSpinnerHeader && !request.url.startsWith('/assets/')) {\r\n      this.loadingService.loading$.next(true);\r\n      this.activeRequests.push(this.getUrlWithoutParams(request.url));\r\n    }\r\n\r\n    return next.handle(request).pipe(\r\n      catchError((response: HttpErrorResponse) => {\r\n        if (response.error?.messages?.length) {\r\n          this.errorMessageService.genericModalErrorMessage$.next(\r\n            response.error.messages[response.error.messages.length - 1]\r\n          );\r\n        }\r\n        if (!this.isRefreshTokenRequest(request.url)) {\r\n          if (response.status === 401) {\r\n            return this.handle401Error(request, next);\r\n          }\r\n          if (response.status === 403) {\r\n            this.errorMessageService.genericModalErrorMessage$.next('Usuário sem privilégios para realizar essa ação');\r\n          }\r\n        }\r\n        if (this.activeRequests.includes(this.getUrlWithoutParams(response.url))) {\r\n          this.activeRequests.splice(\r\n            this.activeRequests.findIndex((item) => item === this.getUrlWithoutParams(request.url)),\r\n            1\r\n          );\r\n          if (!this.activeRequests.length) {\r\n            this.loadingService.loading$.next(false);\r\n          }\r\n        }\r\n        return throwError(response);\r\n      }),\r\n      tap((response) => {\r\n        if (response instanceof HttpResponse) {\r\n          if (this.activeRequests.includes(this.getUrlWithoutParams(response.url))) {\r\n            this.activeRequests.splice(\r\n              this.activeRequests.findIndex((item) => item === this.getUrlWithoutParams(request.url)),\r\n              1\r\n            );\r\n            if (!this.activeRequests.length) {\r\n              this.loadingService.loading$.next(false);\r\n            }\r\n          }\r\n\r\n          if (\r\n            Object(response.body).hasOwnProperty('statusCode') &&\r\n            response.body.statusCode === 400 &&\r\n            response.body.messages?.length\r\n          ) {\r\n            this.errorMessageService.genericModalErrorMessage$.next(\r\n              response.body.messages[response.body.messages.length - 1]\r\n            );\r\n          }\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  private isRefreshTokenRequest(url: string) {\r\n    return url.includes('connect/token');\r\n  }\r\n\r\n  private getUrlWithoutParams(fullUrl: string | null): string {\r\n    if (!fullUrl) {\r\n      return '';\r\n    }\r\n\r\n    const decodedUrl = decodeURIComponent(fullUrl.trim());\r\n\r\n    if (!decodedUrl.includes('?')) {\r\n      return decodedUrl;\r\n    }\r\n\r\n    return decodedUrl.substring(0, decodedUrl.indexOf('?'));\r\n  }\r\n\r\n  private addTokenIfPresent(request: HttpRequest<any>): HttpRequest<any> {\r\n    const token = this.storageService.getToken();\r\n    if (token) {\r\n      request = request.clone({ setHeaders: { Authorization: token } });\r\n    }\r\n    return request;\r\n  }\r\n\r\n  private addModifierIdIfPresent(request: HttpRequest<any>): HttpRequest<any> {\r\n    const modifierId = this.storageService.getUserId();\r\n    if (modifierId && request.method !== 'GET' && !(request.body instanceof FormData)) {\r\n      request = request.clone({ body: { ...request.body, modifierId } });\r\n    }\r\n    return request;\r\n  }\r\n\r\n  private addContentType(request: HttpRequest<any>): HttpRequest<any> {\r\n    return request.clone({ setHeaders: { contentType: 'application/json' } });\r\n  }\r\n\r\n  private fixUrl(request: HttpRequest<any>): HttpRequest<any> {\r\n    return request.clone({\r\n      url: request.url.startsWith('/assets/') ? request.url : `${this.environment.API_URL}/${request.url}`,\r\n    });\r\n  }\r\n\r\n  private handle401Error(request: HttpRequest<any>, next: HttpHandler) {\r\n    if (!this.isRefreshing) {\r\n      this.isRefreshing = true;\r\n      this.refreshTokenSubject.next(null);\r\n\r\n      const refreshToken = this.storageService.getRefreshToken();\r\n      if (refreshToken) {\r\n        return this.authService.getTokenByRefreshToken(refreshToken).pipe(\r\n          switchMap((token: any) => {\r\n            this.isRefreshing = false;\r\n            this.refreshTokenSubject.next(this.storageService.getToken());\r\n            return next.handle(this.addTokenIfPresent(request));\r\n          }),\r\n          catchError((err) => {\r\n            this.isRefreshing = false;\r\n            this.authService.logout();\r\n            return throwError(err);\r\n          })\r\n        );\r\n      } else {\r\n        this.isRefreshing = false;\r\n        this.authService.logout();\r\n        return throwError(new Error());\r\n      }\r\n    }\r\n\r\n    return this.refreshTokenSubject.pipe(\r\n      filter((token) => token !== null),\r\n      take(1),\r\n      switchMap((token) => next.handle(this.addTokenIfPresent(request)))\r\n    );\r\n  }\r\n}\r\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-interceptor.js","sourceRoot":"","sources":["../../../../../projects/ngx-vector-components/src/lib/interceptors/http-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  HttpErrorResponse,\r\n  HttpEvent,\r\n  HttpHandler,\r\n  HttpInterceptor,\r\n  HttpRequest,\r\n  HttpResponse,\r\n} from '@angular/common/http';\r\nimport { Inject, Injectable } from '@angular/core';\r\nimport { BehaviorSubject, Observable, throwError } from 'rxjs';\r\nimport { catchError, filter, switchMap, take, tap } from 'rxjs/operators';\r\nimport { AuthService, ErrorMessageService, LoadingService, StorageService } from '../services';\r\n\r\n@Injectable()\r\nexport class HttpInterceptorProvider implements HttpInterceptor {\r\n  private activeRequests: string[] = [];\r\n  private isRefreshing = false;\r\n  private refreshTokenSubject: BehaviorSubject<any> = new BehaviorSubject<any>(null);\r\n\r\n  constructor(\r\n    private storageService: StorageService,\r\n    private errorMessageService: ErrorMessageService,\r\n    private loadingService: LoadingService,\r\n    private authService: AuthService,\r\n    @Inject('environment') private environment: any\r\n  ) {}\r\n\r\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    if (!this.isRefreshTokenRequest(request.url)) {\r\n      request = this.addTokenIfPresent(request);\r\n      request = this.addModifierIdIfPresent(request);\r\n      request = this.addContentType(request);\r\n    }\r\n    request = this.fixUrl(request);\r\n\r\n    const noSpinnerHeader = request.headers.get('no-spinner');\r\n    if (!noSpinnerHeader && !request.url.startsWith('/assets/')) {\r\n      this.loadingService.loading$.next(true);\r\n      this.activeRequests.push(this.getUrlWithoutParams(request.url));\r\n    }\r\n\r\n    return next.handle(request).pipe(\r\n      catchError((response: HttpErrorResponse) => {\r\n        if (response.error?.messages?.length) {\r\n          this.errorMessageService.genericModalErrorMessage$.next(\r\n            response.error.messages[response.error.messages.length - 1]\r\n          );\r\n        }\r\n        if (!this.isRefreshTokenRequest(request.url)) {\r\n          if (response.status === 401) {\r\n            return this.handle401Error(request, next);\r\n          }\r\n          if (response.status === 403) {\r\n            this.errorMessageService.genericModalErrorMessage$.next('Usuário sem privilégios para realizar essa ação');\r\n          }\r\n        }\r\n        if (this.activeRequests.includes(this.getUrlWithoutParams(response.url))) {\r\n          this.activeRequests.splice(\r\n            this.activeRequests.findIndex((item) => item === this.getUrlWithoutParams(request.url)),\r\n            1\r\n          );\r\n          if (!this.activeRequests.length) {\r\n            this.loadingService.loading$.next(false);\r\n          }\r\n        }\r\n        return throwError(response);\r\n      }),\r\n      tap((response) => {\r\n        if (response instanceof HttpResponse) {\r\n          if (this.activeRequests.includes(this.getUrlWithoutParams(response.url))) {\r\n            this.activeRequests.splice(\r\n              this.activeRequests.findIndex((item) => item === this.getUrlWithoutParams(request.url)),\r\n              1\r\n            );\r\n            if (!this.activeRequests.length) {\r\n              this.loadingService.loading$.next(false);\r\n            }\r\n          }\r\n\r\n          if (\r\n            Object(response.body).hasOwnProperty('statusCode') &&\r\n            response.body.statusCode === 400 &&\r\n            response.body.messages?.length\r\n          ) {\r\n            this.errorMessageService.genericModalErrorMessage$.next(\r\n              response.body.messages[response.body.messages.length - 1]\r\n            );\r\n          }\r\n        }\r\n      })\r\n    );\r\n  }\r\n\r\n  private isRefreshTokenRequest(url: string) {\r\n    return url.includes('connect/token');\r\n  }\r\n\r\n  private getUrlWithoutParams(fullUrl: string | null): string {\r\n    if (!fullUrl) {\r\n      return '';\r\n    }\r\n\r\n    const decodedUrl = decodeURIComponent(fullUrl.trim());\r\n\r\n    if (!decodedUrl.includes('?')) {\r\n      return decodedUrl;\r\n    }\r\n\r\n    return decodedUrl.substring(0, decodedUrl.indexOf('?'));\r\n  }\r\n\r\n  private addTokenIfPresent(request: HttpRequest<any>): HttpRequest<any> {\r\n    const token = this.storageService.getToken();\r\n    if (token) {\r\n      request = request.clone({ setHeaders: { Authorization: token } });\r\n    }\r\n    return request;\r\n  }\r\n\r\n  private addModifierIdIfPresent(request: HttpRequest<any>): HttpRequest<any> {\r\n    const modifierId = this.storageService.getUserId();\r\n    if (modifierId && request.method !== 'GET' && !(request.body instanceof FormData)) {\r\n      request = request.clone({ body: { ...request.body, modifierId } });\r\n    }\r\n    return request;\r\n  }\r\n\r\n  private addContentType(request: HttpRequest<any>): HttpRequest<any> {\r\n    return request.clone({ setHeaders: { contentType: 'application/json' } });\r\n  }\r\n\r\n  private fixUrl(request: HttpRequest<any>): HttpRequest<any> {\r\n    if (this.isAuthRequest(request.url) || this.isProfilesRequest(request.url)) {\r\n      return request.clone({\r\n        url: `${this.environment.API_URL.replace('/api', '')}/${request.url}`,\r\n      });\r\n    }\r\n    return request.clone({\r\n      url: request.url.startsWith('/assets/') ? request.url : `${this.environment.API_URL}/${request.url}`,\r\n    });\r\n  }\r\n\r\n  private isAuthRequest(url: string) {\r\n    return url.includes('connect/token');\r\n  }\r\n\r\n  private isProfilesRequest(url: string) {\r\n    return url.includes('connect/userinfo');\r\n  }\r\n\r\n  private handle401Error(request: HttpRequest<any>, next: HttpHandler) {\r\n    if (!this.isRefreshing) {\r\n      this.isRefreshing = true;\r\n      this.refreshTokenSubject.next(null);\r\n\r\n      const refreshToken = this.storageService.getRefreshToken();\r\n      if (refreshToken) {\r\n        return this.authService.getTokenByRefreshToken(refreshToken).pipe(\r\n          switchMap((token: any) => {\r\n            this.isRefreshing = false;\r\n            this.refreshTokenSubject.next(this.storageService.getToken());\r\n            return next.handle(this.addTokenIfPresent(request));\r\n          }),\r\n          catchError((err) => {\r\n            this.isRefreshing = false;\r\n            this.authService.logout();\r\n            return throwError(err);\r\n          })\r\n        );\r\n      } else {\r\n        this.isRefreshing = false;\r\n        this.authService.logout();\r\n        return throwError(new Error());\r\n      }\r\n    }\r\n\r\n    return this.refreshTokenSubject.pipe(\r\n      filter((token) => token !== null),\r\n      take(1),\r\n      switchMap((token) => next.handle(this.addTokenIfPresent(request)))\r\n    );\r\n  }\r\n}\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1yZXNwb25zZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL21vZGVscy9odHRwLXJlc3BvbnNlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBIdHRwUmVzcG9uc2U8VD4gPSB7XHJcbiAgc3VjY2VzczogYm9vbGVhbjtcclxuICBzdGF0dXNDb2RlOiBudW1iZXI7XHJcbiAgZGF0YTogVDtcclxuICBtZXNzYWdlczogYW55W107XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBIdHRwUmVzcG9uc2VQYWdlZDxUPiA9IHtcclxuICBkYXRhOiBUW107XHJcbiAgcGFnZTogbnVtYmVyO1xyXG4gIHRvdGFsQ291bnQ6IG51bWJlcjtcclxuICB0b3RhbFBhZ2VzOiBudW1iZXI7XHJcbn07XHJcblxyXG5leHBvcnQgdHlwZSBIdHRwUmVzcG9uc2VHcmlkUGFnZWQ8VD4gPSB7XHJcbiAgZGF0YTogVFtdO1xyXG4gIGRyYXc6IG51bWJlcjtcclxuICByZWNvcmRzRmlsdGVyZWQ6IG51bWJlcjtcclxuICByZWNvcmRzVG90YWw6IG51bWJlcjtcclxufTtcclxuXHJcbmV4cG9ydCB0eXBlIEh0dHBMZWdhY3lMaXN0SXRlbSA9IHtcclxuICB0ZXh0OiBzdHJpbmc7XHJcbiAgdmFsdWU6IG51bWJlcjtcclxufTtcclxuXHJcbmV4cG9ydCB0eXBlIEh0dHBMZWdhY3lJdGVtRGF0YTxUPiA9IHtcclxuICBkOiBUO1xyXG59O1xyXG5cclxuZXhwb3J0IHR5cGUgSHR0cExlZ2FjeUNydWRBY3Rpb25SZXNwb25zZSA9IHtcclxuICBkaXNwbGF5TXNnOiBib29sZWFuO1xyXG4gIGVycm9yQ29kZTogbnVtYmVyO1xyXG4gIG1zZ0NvZGU6IG51bWJlcjtcclxuICBvazogYm9vbGVhbjtcclxuICByZXN1bHQ6IG51bWJlcjtcclxufTtcclxuIl19
|