mapa-library-ui 0.74.1 → 0.74.3

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.
Files changed (97) hide show
  1. package/esm2020/lib/core/interfaces/element-option.interface.mjs +1 -1
  2. package/esm2020/src/lib/components/capability/lib/components/dropdown/src/dropdown.component.mjs +14 -6
  3. package/esm2020/src/lib/components/capability/lib/core/interfaces/element-option.interface.mjs +1 -1
  4. package/esm2020/src/lib/components/chart/lib/components/dropdown/src/dropdown.component.mjs +14 -6
  5. package/esm2020/src/lib/components/chart/lib/core/interfaces/element-option.interface.mjs +1 -1
  6. package/esm2020/src/lib/components/dropdown/lib/components/dropdown/src/dropdown.component.mjs +14 -6
  7. package/esm2020/src/lib/components/dropdown/lib/components/dropdown-tree/src/dropdown.component.mjs +3 -1
  8. package/esm2020/src/lib/components/dropdown/lib/core/interfaces/element-option.interface.mjs +1 -1
  9. package/esm2020/src/lib/components/dropdown-tree/lib/components/dropdown/src/dropdown.component.mjs +14 -6
  10. package/esm2020/src/lib/components/dropdown-tree/lib/components/dropdown-tree/src/dropdown.component.mjs +3 -1
  11. package/esm2020/src/lib/components/dropdown-tree/lib/core/interfaces/element-option.interface.mjs +1 -1
  12. package/esm2020/src/lib/components/form/lib/core/interfaces/element-option.interface.mjs +1 -1
  13. package/esm2020/src/lib/components/group-report/lib/components/dropdown/src/dropdown.component.mjs +14 -6
  14. package/esm2020/src/lib/components/group-report/lib/core/interfaces/element-option.interface.mjs +1 -1
  15. package/esm2020/src/lib/components/nav-list/lib/core/interfaces/element-option.interface.mjs +1 -1
  16. package/esm2020/src/lib/components/radio-button/lib/core/interfaces/element-option.interface.mjs +1 -1
  17. package/esm2020/src/lib/components/scale/lib/components/dropdown/src/dropdown.component.mjs +14 -6
  18. package/esm2020/src/lib/components/scale/lib/core/interfaces/element-option.interface.mjs +1 -1
  19. package/esm2020/src/lib/components/scale-parameterization/lib/components/dropdown/src/dropdown.component.mjs +14 -6
  20. package/esm2020/src/lib/components/scale-parameterization/lib/core/interfaces/element-option.interface.mjs +1 -1
  21. package/esm2020/src/lib/components/slide-toggle/lib/core/interfaces/element-option.interface.mjs +1 -1
  22. package/esm2020/src/lib/components/svg-icon/lib/components/svg-icon/public-api.mjs +6 -0
  23. package/esm2020/src/lib/components/svg-icon/lib/components/svg-icon/src/safe-html.pipe.mjs +20 -0
  24. package/esm2020/src/lib/components/svg-icon/lib/components/svg-icon/src/svg-icon.component.mjs +48 -0
  25. package/esm2020/src/lib/components/svg-icon/lib/components/svg-icon/src/svg-icon.module.mjs +19 -0
  26. package/esm2020/src/lib/components/svg-icon/mapa-library-ui-src-lib-components-svg-icon.mjs +5 -0
  27. package/esm2020/src/lib/components/svg-icon/svg-icon.mjs +5 -0
  28. package/esm2020/src/lib/components/table/lib/components/svg-icon/public-api.mjs +6 -0
  29. package/esm2020/src/lib/components/table/lib/components/svg-icon/src/safe-html.pipe.mjs +20 -0
  30. package/esm2020/src/lib/components/table/lib/components/svg-icon/src/svg-icon.component.mjs +48 -0
  31. package/esm2020/src/lib/components/table/lib/components/svg-icon/src/svg-icon.module.mjs +19 -0
  32. package/esm2020/src/lib/components/table/lib/components/table/src/table.component.mjs +14 -10
  33. package/esm2020/src/lib/components/table/lib/components/table/src/table.module.mjs +5 -1
  34. package/esm2020/src/lib/components/textarea/lib/core/interfaces/element-option.interface.mjs +1 -1
  35. package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs +13 -5
  36. package/fesm2015/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
  37. package/fesm2015/mapa-library-ui-src-lib-components-chart.mjs +13 -5
  38. package/fesm2015/mapa-library-ui-src-lib-components-chart.mjs.map +1 -1
  39. package/fesm2015/mapa-library-ui-src-lib-components-dropdown-tree.mjs +15 -5
  40. package/fesm2015/mapa-library-ui-src-lib-components-dropdown-tree.mjs.map +1 -1
  41. package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs +15 -5
  42. package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
  43. package/fesm2015/mapa-library-ui-src-lib-components-scale-parameterization.mjs +13 -5
  44. package/fesm2015/mapa-library-ui-src-lib-components-scale-parameterization.mjs.map +1 -1
  45. package/fesm2015/mapa-library-ui-src-lib-components-svg-icon.mjs +95 -0
  46. package/fesm2015/mapa-library-ui-src-lib-components-svg-icon.mjs.map +1 -0
  47. package/fesm2015/mapa-library-ui-src-lib-components-table.mjs +94 -7
  48. package/fesm2015/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
  49. package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs +13 -5
  50. package/fesm2020/mapa-library-ui-src-lib-components-capability.mjs.map +1 -1
  51. package/fesm2020/mapa-library-ui-src-lib-components-chart.mjs +13 -5
  52. package/fesm2020/mapa-library-ui-src-lib-components-chart.mjs.map +1 -1
  53. package/fesm2020/mapa-library-ui-src-lib-components-dropdown-tree.mjs +15 -5
  54. package/fesm2020/mapa-library-ui-src-lib-components-dropdown-tree.mjs.map +1 -1
  55. package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs +15 -5
  56. package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
  57. package/fesm2020/mapa-library-ui-src-lib-components-scale-parameterization.mjs +13 -5
  58. package/fesm2020/mapa-library-ui-src-lib-components-scale-parameterization.mjs.map +1 -1
  59. package/fesm2020/mapa-library-ui-src-lib-components-svg-icon.mjs +95 -0
  60. package/fesm2020/mapa-library-ui-src-lib-components-svg-icon.mjs.map +1 -0
  61. package/fesm2020/mapa-library-ui-src-lib-components-table.mjs +93 -7
  62. package/fesm2020/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
  63. package/lib/core/interfaces/element-option.interface.d.ts +1 -0
  64. package/mapa-library-ui-0.74.3.tgz +0 -0
  65. package/package.json +9 -1
  66. package/src/lib/components/capability/lib/components/dropdown/src/dropdown.component.d.ts +1 -0
  67. package/src/lib/components/capability/lib/core/interfaces/element-option.interface.d.ts +1 -0
  68. package/src/lib/components/chart/lib/components/dropdown/src/dropdown.component.d.ts +1 -0
  69. package/src/lib/components/chart/lib/core/interfaces/element-option.interface.d.ts +1 -0
  70. package/src/lib/components/dropdown/lib/components/dropdown/src/dropdown.component.d.ts +1 -0
  71. package/src/lib/components/dropdown/lib/core/interfaces/element-option.interface.d.ts +1 -0
  72. package/src/lib/components/dropdown-tree/lib/components/dropdown/src/dropdown.component.d.ts +1 -0
  73. package/src/lib/components/dropdown-tree/lib/core/interfaces/element-option.interface.d.ts +1 -0
  74. package/src/lib/components/form/lib/core/interfaces/element-option.interface.d.ts +1 -0
  75. package/src/lib/components/group-report/lib/components/dropdown/src/dropdown.component.d.ts +1 -0
  76. package/src/lib/components/group-report/lib/core/interfaces/element-option.interface.d.ts +1 -0
  77. package/src/lib/components/nav-list/lib/core/interfaces/element-option.interface.d.ts +1 -0
  78. package/src/lib/components/radio-button/lib/core/interfaces/element-option.interface.d.ts +1 -0
  79. package/src/lib/components/scale/lib/components/dropdown/src/dropdown.component.d.ts +1 -0
  80. package/src/lib/components/scale/lib/core/interfaces/element-option.interface.d.ts +1 -0
  81. package/src/lib/components/scale-parameterization/lib/components/dropdown/src/dropdown.component.d.ts +1 -0
  82. package/src/lib/components/scale-parameterization/lib/core/interfaces/element-option.interface.d.ts +1 -0
  83. package/src/lib/components/slide-toggle/lib/core/interfaces/element-option.interface.d.ts +1 -0
  84. package/src/lib/components/svg-icon/index.d.ts +5 -0
  85. package/src/lib/components/svg-icon/lib/components/svg-icon/public-api.d.ts +2 -0
  86. package/src/lib/components/svg-icon/lib/components/svg-icon/src/safe-html.pipe.d.ts +10 -0
  87. package/src/lib/components/svg-icon/lib/components/svg-icon/src/svg-icon.component.d.ts +14 -0
  88. package/src/lib/components/svg-icon/lib/components/svg-icon/src/svg-icon.module.d.ts +9 -0
  89. package/src/lib/components/svg-icon/svg-icon.d.ts +1 -0
  90. package/src/lib/components/table/lib/components/svg-icon/public-api.d.ts +2 -0
  91. package/src/lib/components/table/lib/components/svg-icon/src/safe-html.pipe.d.ts +10 -0
  92. package/src/lib/components/table/lib/components/svg-icon/src/svg-icon.component.d.ts +14 -0
  93. package/src/lib/components/table/lib/components/svg-icon/src/svg-icon.module.d.ts +9 -0
  94. package/src/lib/components/table/lib/components/table/src/table.component.d.ts +1 -0
  95. package/src/lib/components/table/lib/components/table/src/table.module.d.ts +11 -10
  96. package/src/lib/components/textarea/lib/core/interfaces/element-option.interface.d.ts +1 -0
  97. package/mapa-library-ui-0.74.1.tgz +0 -0
@@ -62,17 +62,17 @@ export class MapaDropdownComponent {
62
62
  }
63
63
  }
64
64
  filterOptionsFromGroup(group, value) {
65
- const filterValue = value.toLocaleLowerCase();
66
- return group.label.toLocaleLowerCase().includes(filterValue)
65
+ const filterValue = this.normalizeValue(value);
66
+ return this.normalizeValue(group.label).includes(filterValue)
67
67
  ? group.options
68
- : group.options.filter((item) => item.value.toLocaleLowerCase().includes(filterValue));
68
+ : group.options.filter((item) => this.normalizeValue(item.value).includes(filterValue));
69
69
  }
70
70
  filterOptions() {
71
71
  if (!this.element.options) {
72
72
  return;
73
73
  }
74
74
  // get the search keyword
75
- let search = this.element.search?.formControl?.value.toLowerCase();
75
+ let search = this.normalizeValue(this.element.search?.formControl?.value);
76
76
  if (this.isOptionsGroup) {
77
77
  const groups = this.element.options;
78
78
  this.filteredGroupCache = groups
@@ -91,10 +91,18 @@ export class MapaDropdownComponent {
91
91
  return;
92
92
  }
93
93
  // filter the options
94
- this.filteredOptionsCache = options.filter((option) => option.value.toLowerCase().indexOf(search) > -1);
94
+ this.filteredOptionsCache = options.filter((option) => this.normalizeValue(option.value).indexOf(search) > -1);
95
95
  this.filteredOptions.next(this.filteredOptionsCache);
96
96
  }
97
97
  }
98
+ normalizeValue(value) {
99
+ const normalizedValue = value
100
+ .normalize('NFD')
101
+ .replace(/[\u0300-\u036f]/g, "")
102
+ .toLowerCase();
103
+ console.log(normalizedValue);
104
+ return normalizedValue;
105
+ }
98
106
  setToggleAllCheckboxState() {
99
107
  let filteredLength = 0;
100
108
  let search = this.element.search?.formControl?.value;
@@ -175,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
175
183
  type: ViewChild,
176
184
  args: ["dropdown", { static: true }]
177
185
  }] } });
178
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown/src/dropdown.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\n\nimport { MatSelect } from \"@angular/material/select\";\n\nimport { ReplaySubject } from \"rxjs/internal/ReplaySubject\";\nimport { Subject } from \"rxjs/internal/Subject\";\n//import { take, takeUntil } from \"rxjs/operators\";\n\nimport { ElementOption } from \"../../../core/interfaces/element-option.interface\";\nimport { Dropdown } from \"../../../core/elements/dropdown\";\nimport { ElementGroup } from \"../../../core/interfaces/element-group.interface\";\nimport { MatCheckboxChange } from \"@angular/material/checkbox\";\n\n@Component({\n  selector: \"mapa-dropdown\",\n  templateUrl: \"./dropdown.component.html\",\n  styleUrls: [\"./dropdown.component.scss\"],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaDropdownComponent implements OnInit, OnDestroy, OnChanges {\n  @Input() formControl!: FormControl;\n  @Input() formControlSearch!: FormControl;\n  @Input() element!: Dropdown;\n  @Input() border: \"soft\" | \"tag\" | \"highlight\" | null | undefined;\n\n  @ViewChild(\"dropdown\", { static: true }) dropdown!: MatSelect;\n\n  public filteredOptions: ReplaySubject<ElementOption[]> = new ReplaySubject<\n    ElementOption[]\n  >(1);\n  public filteredGroups: ReplaySubject<ElementGroup[]> = new ReplaySubject<\n    ElementGroup[]\n  >(1);\n  protected filteredOptionsCache: ElementOption[] = [];\n  protected filteredGroupCache: ElementGroup[] = [];\n  protected _onDestroy = new Subject<void>();\n\n  isIndeterminate = false;\n  isChecked = false;\n  isOptionsGroup = false;\n\n  get selectedOptions() {\n    const value = this.formControl?.value || [];\n    return Array.isArray(value)? value: [value];\n  }\n\n  constructor() {}\n\n  ngOnInit() {\n    this.setOptions();\n\n    if (this.element.search) {\n      this.element.search.formControl?.valueChanges\n        //.pipe(takeUntil(this._onDestroy))\n        .subscribe(() => {\n          this.filterOptions();\n          this.setToggleAllCheckboxState();\n        });\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes[\"element\"].previousValue?.controlType === \"dropdown\" &&\n      changes[\"element\"].previousValue?.options !== changes[\"element\"].currentValue?.options\n    ) {\n      this.element.options = changes[\"element\"].currentValue.options;\n      this.setOptions();\n    }\n  }\n\n  ngOnDestroy() {\n    this._onDestroy.next();\n    this._onDestroy.complete();\n  }\n\n  setOptions(): void {\n    this.isOptionsGroup = this.isElementGroup(this.element.options[0]);\n\n    if (this.isOptionsGroup) {\n      this.filteredGroupCache = (this.element\n        .options as ElementGroup[]).slice();\n      this.filteredGroups.next(this.filteredGroupCache);\n    } else {\n      this.filteredOptionsCache = (this.element\n        .options as ElementOption[]).slice();\n      this.filteredOptions.next(this.filteredOptionsCache);\n    }\n  }\n\n  protected filterOptionsFromGroup(\n    group: ElementGroup,\n    value: string\n  ): ElementOption[] {\n    const filterValue = value.toLocaleLowerCase();\n\n    return group.label.toLocaleLowerCase().includes(filterValue)\n      ? group.options\n      : group.options.filter((item) =>\n          item.value.toLocaleLowerCase().includes(filterValue)\n        );\n  }\n\n  protected filterOptions() {\n    if (!this.element.options) {\n      return;\n    }\n    // get the search keyword\n    let search = this.element.search?.formControl?.value.toLowerCase();\n\n    if (this.isOptionsGroup) {\n      const groups = this.element.options as ElementGroup[];\n      this.filteredGroupCache = groups\n        .map((group: ElementGroup) => ({\n          label: group.label,\n          options: this.filterOptionsFromGroup(group, search),\n        }))\n        .filter((group) => group.options.length > 0);\n      this.filteredGroups.next(this.filteredGroupCache);\n    } else {\n      const options = this.element.options as ElementOption[];\n      if (!search) {\n        this.filteredOptionsCache = options.slice();\n        this.filteredOptions.next(this.filteredOptionsCache);\n        return;\n      }\n      // filter the options\n      this.filteredOptionsCache = options.filter(\n        (option: ElementOption) =>\n          option.value.toLowerCase().indexOf(search) > -1\n      );\n      this.filteredOptions.next(this.filteredOptionsCache);\n    }\n  }\n\n  protected setToggleAllCheckboxState() {\n    let filteredLength = 0;\n    let search = this.element.search?.formControl?.value;\n\n    if (search && search.value) {\n      this.filteredOptionsCache.forEach((el) => {\n        if (search.value.toLowerCase().indexOf(el) > -1) {\n          filteredLength++;\n        }\n      });\n      this.isIndeterminate =\n        filteredLength > 0 && filteredLength < this.filteredOptionsCache.length;\n      this.isChecked =\n        filteredLength > 0 &&\n        filteredLength === this.filteredOptionsCache.length;\n    }\n  }\n\n  toggleSelectAll(event: MatCheckboxChange) {\n    const selectAllValue = event.checked;\n    this.filteredOptions.subscribe((options: ElementOption[]) => {\n      if (selectAllValue) {\n        this.formControl?.patchValue(options);\n      } else {\n        this.formControl?.patchValue([]);\n      }\n    });\n    this.filteredGroups.subscribe((groups: ElementGroup[]) => {\n      if (selectAllValue) {\n        this.formControl?.patchValue(\n          groups.map((group: ElementGroup) => group.options)\n        );\n      } else {\n        this.formControl?.patchValue([]);\n      }\n    });\n  }\n\n  toggleSelection(change: MatCheckboxChange): void {\n    if (change.checked) {\n      this.formControl?.setValue(this.filteredOptions);\n    } else {\n      this.formControl?.setValue([]);\n    }\n  }  \n  \n  isElementGroup(object: ElementGroup | ElementOption): object is ElementGroup {\n    try {\n      return (\n        (object as ElementGroup).label !== undefined &&\n        (object as ElementGroup).options !== undefined\n      );\n    } catch (e) {\n      return false;\n    }\n  }\n\n  compareFn(c1: any, c2: any): boolean {\n    return c1 && c2 ? c1.key === c2.key : c1 === c2;\n  }\n  \n  hasValue(): boolean {\n    return !!this.formControl.value;\n  }\n\n  clearValue(event: any): void {\n    event.stopPropagation();\n    this.formControl.setValue(null);\n  }\n}\n","<div *ngIf=\"element\">\n  <label *ngIf=\"element.label\" class=\"mapa-dropdown__label\">\n    {{ element.label }}\n  </label>\n  <div class=\"mapa-form--inline\">\n    <mat-form-field\n      appearance=\"outline\"\n      class=\"mapa-dropdown\"\n      [class.mapa-dropdown--highlight]=\"border === 'highlight'\"\n      [class.mapa-dropdown--soft-border]=\"border === 'soft'\"\n      [class.mapa-dropdown--tag]=\"border === 'tag'\"\n      [class.mapa-dropdown--labeled]=\"!!element.label\"\n    >\n      <mat-select\n        #dropdown\n        ngDefaultControl\n        [formControl]=\"formControl\"\n        [multiple]=\"element.multiple\"\n        [placeholder]=\"element.placeholder || ''\"\n        [compareWith]=\"compareFn\"\n      >\n        <mat-option *ngIf=\"element.search\" class=\"mapa-dropdown__search\">\n          <ngx-mat-select-search\n            *ngIf=\"element.search.formControl\"\n            [showToggleAllCheckbox]=\"element.search.toggleAllCheckbox!\"\n            [formControl]=\"element.search.formControl\"\n            [placeholderLabel]=\"element.search.placeholder || ''\"\n            i18n-placeholderLabel\n            [noEntriesFoundLabel]=\"element.search.noEntriesFoundLabel || ''\"\n          ></ngx-mat-select-search>\n        </mat-option>\n        <mat-option\n          *ngIf=\"element.multiple\"\n          class=\"mapa-dropdown__option--select-all\"\n        >\n          <mat-checkbox\n            class=\"mat-option\"\n            [indeterminate]=\"isIndeterminate\"\n            [checked]=\"isChecked\"\n            (click)=\"$event.stopPropagation()\"\n            (change)=\"toggleSelectAll($event)\"\n          >\n            Selecionar todos\n          </mat-checkbox>\n        </mat-option>\n        <ng-container *ngIf=\"isOptionsGroup; else isElementOptions\">\n          <mat-optgroup\n            *ngFor=\"let group of filteredGroups | async\"\n            [label]=\"group.label\"\n          >\n            <mat-option\n              *ngFor=\"let option of group.options\"\n              [value]=\"option\"\n              [ngClass]=\"[\n                'mapa-dropdown__option--children-level-' + option.childrenLevel\n              ]\"\n            >\n              <span [innerHTML]=\"option.value\"></span>\n            </mat-option>\n          </mat-optgroup>\n        </ng-container>\n        <ng-template #isElementOptions>\n          <mat-option\n            *ngFor=\"let option of filteredOptions | async\"\n            [value]=\"option\"\n            [ngClass]=\"[\n              'mapa-dropdown__option mapa-dropdown__option--children-level-' + option.childrenLevel\n            ]\"\n          >\n            <span class=\"mapa-dropdown__option-value\" [innerHTML]=\"option.value\"></span>\n          </mat-option>\n        </ng-template>\n\n        <mat-option\n          *ngFor=\"let option of selectedOptions\"\n          hidden\n          [value]=\"option\"\n          [ngClass]=\"[\n            'mapa-dropdown__option--children-level-' + option.childrenLevel\n          ]\"\n        >\n          <span [innerHTML]=\"option.value\"></span>\n        </mat-option>\n      </mat-select>\n      <mat-hint *ngIf=\"element.hint\">{{ element.hint }}</mat-hint>\n      <mat-error *ngIf=\"formControl?.hasError('required')\">\n        {{ element.errors?.required }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('minlength')\">\n        {{ element.errors?.minlength }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('cpf')\">\n        {{ element.errors?.cpf }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('cnpj')\">\n        {{ element.errors?.cnpj }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('email')\">\n        {{ element.errors?.email }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('pattern')\">\n        {{ element.errors?.pattern }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('min')\">\n        {{ element.errors?.min }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('max')\">\n        {{ element.errors?.max }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('minlength')\">\n        {{ element.errors?.minLength }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('maxlength')\">\n        {{ element.errors?.maxLength }}\n      </mat-error>\n      <mat-icon\n        *ngIf=\"hasValue() && !formControl.disabled && element.clearValue\"\n        (click)=\"clearValue($event)\"\n        class=\"mapa-input--close\"\n        >close</mat-icon\n      >\n    </mat-form-field>\n    <div *ngIf=\"element.actionButton\" class=\"mapa-form--action\">\n      <mapa-button\n        color=\"basic\"\n        (click)=\"element.actionButton.action.emit(true)\"\n      >\n        {{ element.actionButton.label }}\n      </mapa-button>\n    </div>\n  </div>\n</div>\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown/src/dropdown.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\n\nimport { MatSelect } from \"@angular/material/select\";\n\nimport { ReplaySubject } from \"rxjs/internal/ReplaySubject\";\nimport { Subject } from \"rxjs/internal/Subject\";\n//import { take, takeUntil } from \"rxjs/operators\";\n\nimport { ElementOption } from \"../../../core/interfaces/element-option.interface\";\nimport { Dropdown } from \"../../../core/elements/dropdown\";\nimport { ElementGroup } from \"../../../core/interfaces/element-group.interface\";\nimport { MatCheckboxChange } from \"@angular/material/checkbox\";\n\n@Component({\n  selector: \"mapa-dropdown\",\n  templateUrl: \"./dropdown.component.html\",\n  styleUrls: [\"./dropdown.component.scss\"],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaDropdownComponent implements OnInit, OnDestroy, OnChanges {\n  @Input() formControl!: FormControl;\n  @Input() formControlSearch!: FormControl;\n  @Input() element!: Dropdown;\n  @Input() border: \"soft\" | \"tag\" | \"highlight\" | null | undefined;\n\n  @ViewChild(\"dropdown\", { static: true }) dropdown!: MatSelect;\n\n  public filteredOptions: ReplaySubject<ElementOption[]> = new ReplaySubject<\n    ElementOption[]\n  >(1);\n  public filteredGroups: ReplaySubject<ElementGroup[]> = new ReplaySubject<\n    ElementGroup[]\n  >(1);\n  protected filteredOptionsCache: ElementOption[] = [];\n  protected filteredGroupCache: ElementGroup[] = [];\n  protected _onDestroy = new Subject<void>();\n\n  isIndeterminate = false;\n  isChecked = false;\n  isOptionsGroup = false;\n\n  get selectedOptions() {\n    const value = this.formControl?.value || [];\n    return Array.isArray(value) ? value : [value];\n  }\n\n  constructor() { }\n\n  ngOnInit() {\n    this.setOptions();\n\n    if (this.element.search) {\n      this.element.search.formControl?.valueChanges\n        //.pipe(takeUntil(this._onDestroy))\n        .subscribe(() => {\n          this.filterOptions();\n          this.setToggleAllCheckboxState();\n        });\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes[\"element\"].previousValue?.controlType === \"dropdown\" &&\n      changes[\"element\"].previousValue?.options !== changes[\"element\"].currentValue?.options\n    ) {\n      this.element.options = changes[\"element\"].currentValue.options;\n      this.setOptions();\n    }\n  }\n\n  ngOnDestroy() {\n    this._onDestroy.next();\n    this._onDestroy.complete();\n  }\n\n  setOptions(): void {\n    this.isOptionsGroup = this.isElementGroup(this.element.options[0]);\n\n    if (this.isOptionsGroup) {\n      this.filteredGroupCache = (this.element\n        .options as ElementGroup[]).slice();\n      this.filteredGroups.next(this.filteredGroupCache);\n    } else {\n      this.filteredOptionsCache = (this.element\n        .options as ElementOption[]).slice();\n      this.filteredOptions.next(this.filteredOptionsCache);\n    }\n  }\n\n  protected filterOptionsFromGroup(\n    group: ElementGroup,\n    value: string\n  ): ElementOption[] {\n    const filterValue = this.normalizeValue(value);\n\n    return this.normalizeValue(group.label).includes(filterValue)\n      ? group.options\n      : group.options.filter((item) =>\n        this.normalizeValue(item.value).includes(filterValue)\n      );\n  }\n\n  protected filterOptions() {\n    if (!this.element.options) {\n      return;\n    }\n    // get the search keyword\n    let search = this.normalizeValue(this.element.search?.formControl?.value);\n\n    if (this.isOptionsGroup) {\n      const groups = this.element.options as ElementGroup[];\n      this.filteredGroupCache = groups\n        .map((group: ElementGroup) => ({\n          label: group.label,\n          options: this.filterOptionsFromGroup(group, search),\n        }))\n        .filter((group) => group.options.length > 0);\n      this.filteredGroups.next(this.filteredGroupCache);\n    } else {\n      const options = this.element.options as ElementOption[];\n      if (!search) {\n        this.filteredOptionsCache = options.slice();\n        this.filteredOptions.next(this.filteredOptionsCache);\n        return;\n      }\n      // filter the options\n      this.filteredOptionsCache = options.filter(\n        (option: ElementOption) =>\n          this.normalizeValue(option.value).indexOf(search) > -1\n      );\n      this.filteredOptions.next(this.filteredOptionsCache);\n    }\n  }\n\n  normalizeValue(value: string): string {\n    const normalizedValue = value\n      .normalize('NFD')\n      .replace(/[\\u0300-\\u036f]/g, \"\")\n      .toLowerCase();\n    console.log(normalizedValue);\n    return normalizedValue;\n  }\n\n  protected setToggleAllCheckboxState() {\n    let filteredLength = 0;\n    let search = this.element.search?.formControl?.value;\n\n    if (search && search.value) {\n      this.filteredOptionsCache.forEach((el) => {\n        if (search.value.toLowerCase().indexOf(el) > -1) {\n          filteredLength++;\n        }\n      });\n      this.isIndeterminate =\n        filteredLength > 0 && filteredLength < this.filteredOptionsCache.length;\n      this.isChecked =\n        filteredLength > 0 &&\n        filteredLength === this.filteredOptionsCache.length;\n    }\n  }\n\n  toggleSelectAll(event: MatCheckboxChange) {\n    const selectAllValue = event.checked;\n    this.filteredOptions.subscribe((options: ElementOption[]) => {\n      if (selectAllValue) {\n        this.formControl?.patchValue(options);\n      } else {\n        this.formControl?.patchValue([]);\n      }\n    });\n    this.filteredGroups.subscribe((groups: ElementGroup[]) => {\n      if (selectAllValue) {\n        this.formControl?.patchValue(\n          groups.map((group: ElementGroup) => group.options)\n        );\n      } else {\n        this.formControl?.patchValue([]);\n      }\n    });\n  }\n\n  toggleSelection(change: MatCheckboxChange): void {\n    if (change.checked) {\n      this.formControl?.setValue(this.filteredOptions);\n    } else {\n      this.formControl?.setValue([]);\n    }\n  }\n\n  isElementGroup(object: ElementGroup | ElementOption): object is ElementGroup {\n    try {\n      return (\n        (object as ElementGroup).label !== undefined &&\n        (object as ElementGroup).options !== undefined\n      );\n    } catch (e) {\n      return false;\n    }\n  }\n\n  compareFn(c1: any, c2: any): boolean {\n    return c1 && c2 ? c1.key === c2.key : c1 === c2;\n  }\n\n  hasValue(): boolean {\n    return !!this.formControl.value;\n  }\n\n  clearValue(event: any): void {\n    event.stopPropagation();\n    this.formControl.setValue(null);\n  }\n}\n","<div *ngIf=\"element\">\n  <label *ngIf=\"element.label\" class=\"mapa-dropdown__label\">\n    {{ element.label }}\n  </label>\n  <div class=\"mapa-form--inline\">\n    <mat-form-field\n      appearance=\"outline\"\n      class=\"mapa-dropdown\"\n      [class.mapa-dropdown--highlight]=\"border === 'highlight'\"\n      [class.mapa-dropdown--soft-border]=\"border === 'soft'\"\n      [class.mapa-dropdown--tag]=\"border === 'tag'\"\n      [class.mapa-dropdown--labeled]=\"!!element.label\"\n    >\n      <mat-select\n        #dropdown\n        ngDefaultControl\n        [formControl]=\"formControl\"\n        [multiple]=\"element.multiple\"\n        [placeholder]=\"element.placeholder || ''\"\n        [compareWith]=\"compareFn\"\n      >\n        <mat-option *ngIf=\"element.search\" class=\"mapa-dropdown__search\">\n          <ngx-mat-select-search\n            *ngIf=\"element.search.formControl\"\n            [showToggleAllCheckbox]=\"element.search.toggleAllCheckbox!\"\n            [formControl]=\"element.search.formControl\"\n            [placeholderLabel]=\"element.search.placeholder || ''\"\n            i18n-placeholderLabel\n            [noEntriesFoundLabel]=\"element.search.noEntriesFoundLabel || ''\"\n          ></ngx-mat-select-search>\n        </mat-option>\n        <mat-option\n          *ngIf=\"element.multiple\"\n          class=\"mapa-dropdown__option--select-all\"\n        >\n          <mat-checkbox\n            class=\"mat-option\"\n            [indeterminate]=\"isIndeterminate\"\n            [checked]=\"isChecked\"\n            (click)=\"$event.stopPropagation()\"\n            (change)=\"toggleSelectAll($event)\"\n          >\n            Selecionar todos\n          </mat-checkbox>\n        </mat-option>\n        <ng-container *ngIf=\"isOptionsGroup; else isElementOptions\">\n          <mat-optgroup\n            *ngFor=\"let group of filteredGroups | async\"\n            [label]=\"group.label\"\n          >\n            <mat-option\n              *ngFor=\"let option of group.options\"\n              [value]=\"option\"\n              [ngClass]=\"[\n                'mapa-dropdown__option--children-level-' + option.childrenLevel\n              ]\"\n            >\n              <span [innerHTML]=\"option.value\"></span>\n            </mat-option>\n          </mat-optgroup>\n        </ng-container>\n        <ng-template #isElementOptions>\n          <mat-option\n            *ngFor=\"let option of filteredOptions | async\"\n            [value]=\"option\"\n            [ngClass]=\"[\n              'mapa-dropdown__option mapa-dropdown__option--children-level-' + option.childrenLevel\n            ]\"\n          >\n            <span class=\"mapa-dropdown__option-value\" [innerHTML]=\"option.value\"></span>\n          </mat-option>\n        </ng-template>\n\n        <mat-option\n          *ngFor=\"let option of selectedOptions\"\n          hidden\n          [value]=\"option\"\n          [ngClass]=\"[\n            'mapa-dropdown__option--children-level-' + option.childrenLevel\n          ]\"\n        >\n          <span [innerHTML]=\"option.value\"></span>\n        </mat-option>\n      </mat-select>\n      <mat-hint *ngIf=\"element.hint\">{{ element.hint }}</mat-hint>\n      <mat-error *ngIf=\"formControl?.hasError('required')\">\n        {{ element.errors?.required }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('minlength')\">\n        {{ element.errors?.minlength }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('cpf')\">\n        {{ element.errors?.cpf }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('cnpj')\">\n        {{ element.errors?.cnpj }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('email')\">\n        {{ element.errors?.email }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('pattern')\">\n        {{ element.errors?.pattern }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('min')\">\n        {{ element.errors?.min }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('max')\">\n        {{ element.errors?.max }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('minlength')\">\n        {{ element.errors?.minLength }}\n      </mat-error>\n      <mat-error *ngIf=\"formControl?.hasError('maxlength')\">\n        {{ element.errors?.maxLength }}\n      </mat-error>\n      <mat-icon\n        *ngIf=\"hasValue() && !formControl.disabled && element.clearValue\"\n        (click)=\"clearValue($event)\"\n        class=\"mapa-input--close\"\n        >close</mat-icon\n      >\n    </mat-form-field>\n    <div *ngIf=\"element.actionButton\" class=\"mapa-form--action\">\n      <mapa-button\n        color=\"basic\"\n        (click)=\"element.actionButton.action.emit(true)\"\n      >\n        {{ element.actionButton.label }}\n      </mapa-button>\n    </div>\n  </div>\n</div>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC1vcHRpb24uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29yZS9pbnRlcmZhY2VzL2VsZW1lbnQtb3B0aW9uLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBFbGVtZW50T3B0aW9uIHtcbiAga2V5OiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIGNoaWxkcmVuTGV2ZWw/OiBudW1iZXIgfCBudWxsO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC1vcHRpb24uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29yZS9pbnRlcmZhY2VzL2VsZW1lbnQtb3B0aW9uLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBFbGVtZW50T3B0aW9uIHtcbiAga2V5OiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIGNoaWxkcmVuPzogRWxlbWVudE9wdGlvbltdO1xuICBjaGlsZHJlbkxldmVsPzogbnVtYmVyIHwgbnVsbDtcbn1cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC1vcHRpb24uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29yZS9pbnRlcmZhY2VzL2VsZW1lbnQtb3B0aW9uLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBFbGVtZW50T3B0aW9uIHtcbiAga2V5OiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIGNoaWxkcmVuTGV2ZWw/OiBudW1iZXIgfCBudWxsO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC1vcHRpb24uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29yZS9pbnRlcmZhY2VzL2VsZW1lbnQtb3B0aW9uLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBFbGVtZW50T3B0aW9uIHtcbiAga2V5OiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG4gIGNoaWxkcmVuPzogRWxlbWVudE9wdGlvbltdO1xuICBjaGlsZHJlbkxldmVsPzogbnVtYmVyIHwgbnVsbDtcbn1cbiJdfQ==
@@ -0,0 +1,6 @@
1
+ /*
2
+ * Public API Surface of mapa-library-ui svg-icon
3
+ */
4
+ export * from './src/svg-icon.component';
5
+ export * from './src/svg-icon.module';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hcGEtbGlicmFyeS11aS9zcmMvbGliL2NvbXBvbmVudHMvc3ZnLWljb24vcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgbWFwYS1saWJyYXJ5LXVpIHN2Zy1pY29uXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9zcmMvc3ZnLWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3N2Zy1pY29uLm1vZHVsZSc7Il19
@@ -0,0 +1,20 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/platform-browser";
4
+ export class SafeHtmlPipe {
5
+ constructor(sanitized) {
6
+ this.sanitized = sanitized;
7
+ }
8
+ transform(value) {
9
+ return this.sanitized.bypassSecurityTrustHtml(value);
10
+ }
11
+ }
12
+ SafeHtmlPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SafeHtmlPipe, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Pipe });
13
+ SafeHtmlPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: SafeHtmlPipe, name: "safeHtml" });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SafeHtmlPipe, decorators: [{
15
+ type: Pipe,
16
+ args: [{
17
+ name: 'safeHtml',
18
+ }]
19
+ }], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; } });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS1odG1sLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb21wb25lbnRzL3N2Zy1pY29uL3NyYy9zYWZlLWh0bWwucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7O0FBTXBELE1BQU0sT0FBTyxZQUFZO0lBRXZCLFlBQW9CLFNBQXVCO1FBQXZCLGNBQVMsR0FBVCxTQUFTLENBQWM7SUFBRyxDQUFDO0lBRS9DLFNBQVMsQ0FBQyxLQUFhO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2RCxDQUFDOzswR0FOVSxZQUFZO3dHQUFaLFlBQVk7NEZBQVosWUFBWTtrQkFIeEIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsVUFBVTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVIdG1sIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ3NhZmVIdG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgU2FmZUh0bWxQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzYW5pdGl6ZWQ6IERvbVNhbml0aXplcikge31cblxuICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZyk6IFNhZmVIdG1sIHtcbiAgICByZXR1cm4gdGhpcy5zYW5pdGl6ZWQuYnlwYXNzU2VjdXJpdHlUcnVzdEh0bWwodmFsdWUpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,48 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common/http";
4
+ import * as i2 from "@angular/common";
5
+ import * as i3 from "./safe-html.pipe";
6
+ export class MapaSvgIconComponent {
7
+ constructor(httpClient, cdr) {
8
+ this.httpClient = httpClient;
9
+ this.cdr = cdr;
10
+ }
11
+ ngOnChanges() {
12
+ if (!this.name) {
13
+ this.svgIcon = '';
14
+ return;
15
+ }
16
+ if (this.color) {
17
+ this.httpClient
18
+ .get(`images/icons/${this.name}.svg`, { responseType: 'text' })
19
+ .subscribe((value) => {
20
+ if (this.color) {
21
+ value = value.replaceAll('fill="#50575E"', `fill="${this.color}"`);
22
+ value = value.replaceAll('fill="#181818"', `fill="${this.color}"`);
23
+ value = value.replaceAll('fill="#7def7b"', `fill="${this.color}"`);
24
+ value = value.replaceAll('stroke="#50575E"', `stroke="${this.color}"`);
25
+ value = value.replaceAll('stroke="#181818"', `stroke="${this.color}"`);
26
+ value = value.replaceAll('stroke="#7def7b"', `stroke="${this.color}"`);
27
+ }
28
+ this.svgIcon = value;
29
+ });
30
+ }
31
+ else {
32
+ const img = `<img src="images/icons/${this.name}.svg" alt="${this.name}" />`;
33
+ this.svgIcon = img;
34
+ }
35
+ this.cdr.detectChanges();
36
+ }
37
+ }
38
+ MapaSvgIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconComponent, deps: [{ token: i1.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
39
+ MapaSvgIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MapaSvgIconComponent, selector: "mapa-svg-icon", inputs: { name: "name", color: "color" }, usesOnChanges: true, ngImport: i0, template: "<span *ngIf=\"svgIcon\" class=\"mapa__svg-icon\" [innerHTML]=\"svgIcon | safeHtml\"></span>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.SafeHtmlPipe, name: "safeHtml" }] });
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconComponent, decorators: [{
41
+ type: Component,
42
+ args: [{ selector: "mapa-svg-icon", template: "<span *ngIf=\"svgIcon\" class=\"mapa__svg-icon\" [innerHTML]=\"svgIcon | safeHtml\"></span>" }]
43
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { name: [{
44
+ type: Input
45
+ }], color: [{
46
+ type: Input
47
+ }] } });
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ZnLWljb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9zdmctaWNvbi9zcmMvc3ZnLWljb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9zdmctaWNvbi9zcmMvc3ZnLWljb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixTQUFTLEVBQUUsS0FBSyxFQUE4QixNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRaEcsTUFBTSxPQUFPLG9CQUFvQjtJQU0vQixZQUFvQixVQUFzQixFQUFVLEdBQXNCO1FBQXRELGVBQVUsR0FBVixVQUFVLENBQVk7UUFBVSxRQUFHLEdBQUgsR0FBRyxDQUFtQjtJQUFJLENBQUM7SUFFeEUsV0FBVztRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNkLElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxDQUFDO1lBQ2xCLE9BQU87U0FDUjtRQUNELElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLElBQUksQ0FBQyxVQUFVO2lCQUNaLEdBQUcsQ0FBQyxnQkFBZ0IsSUFBSSxDQUFDLElBQUksTUFBTSxFQUFFLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxDQUFDO2lCQUM5RCxTQUFTLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRTtnQkFDM0IsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO29CQUNkLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLFNBQVMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ25FLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLFNBQVMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ25FLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLFNBQVMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ25FLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGtCQUFrQixFQUFFLFdBQVcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ3ZFLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGtCQUFrQixFQUFFLFdBQVcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ3ZFLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGtCQUFrQixFQUFFLFdBQVcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7aUJBQ3hFO2dCQUNELElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1lBQ3ZCLENBQUMsQ0FBQyxDQUFDO1NBQ047YUFBTTtZQUNMLE1BQU0sR0FBRyxHQUFHLDBCQUEwQixJQUFJLENBQUMsSUFBSSxjQUFjLElBQUksQ0FBQyxJQUFJLE1BQU0sQ0FBQztZQUM3RSxJQUFJLENBQUMsT0FBTyxHQUFHLEdBQUcsQ0FBQztTQUNwQjtRQUNELElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7a0hBaENVLG9CQUFvQjtzR0FBcEIsb0JBQW9CLG9IQ1JqQyw2RkFBcUY7NEZEUXhFLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxlQUFlO2lJQUtULElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsS0FBSztzQkFBcEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNlY3VyaXR5Q29udGV4dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJtYXBhLXN2Zy1pY29uXCIsXG4gIHRlbXBsYXRlVXJsOiBcIi4vc3ZnLWljb24uY29tcG9uZW50Lmh0bWxcIixcbiAgc3R5bGVVcmxzOiBbXCIuL3N2Zy1pY29uLmNvbXBvbmVudC5zY3NzXCJdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXBhU3ZnSWNvbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIHB1YmxpYyBuYW1lPzogc3RyaW5nO1xuICBASW5wdXQoKSBwdWJsaWMgY29sb3I/OiBzdHJpbmc7XG5cbiAgcHVibGljIHN2Z0ljb246IGFueTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHBDbGllbnQ6IEh0dHBDbGllbnQsIHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikgeyB9XG5cbiAgcHVibGljIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5uYW1lKSB7XG4gICAgICB0aGlzLnN2Z0ljb24gPSAnJztcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgaWYgKHRoaXMuY29sb3IpIHtcbiAgICAgIHRoaXMuaHR0cENsaWVudFxuICAgICAgICAuZ2V0KGBpbWFnZXMvaWNvbnMvJHt0aGlzLm5hbWV9LnN2Z2AsIHsgcmVzcG9uc2VUeXBlOiAndGV4dCcgfSlcbiAgICAgICAgLnN1YnNjcmliZSgodmFsdWU6IHN0cmluZykgPT4ge1xuICAgICAgICAgIGlmICh0aGlzLmNvbG9yKSB7XG4gICAgICAgICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2VBbGwoJ2ZpbGw9XCIjNTA1NzVFXCInLCBgZmlsbD1cIiR7dGhpcy5jb2xvcn1cImApO1xuICAgICAgICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlQWxsKCdmaWxsPVwiIzE4MTgxOFwiJywgYGZpbGw9XCIke3RoaXMuY29sb3J9XCJgKTtcbiAgICAgICAgICAgIHZhbHVlID0gdmFsdWUucmVwbGFjZUFsbCgnZmlsbD1cIiM3ZGVmN2JcIicsIGBmaWxsPVwiJHt0aGlzLmNvbG9yfVwiYCk7XG4gICAgICAgICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2VBbGwoJ3N0cm9rZT1cIiM1MDU3NUVcIicsIGBzdHJva2U9XCIke3RoaXMuY29sb3J9XCJgKTtcbiAgICAgICAgICAgIHZhbHVlID0gdmFsdWUucmVwbGFjZUFsbCgnc3Ryb2tlPVwiIzE4MTgxOFwiJywgYHN0cm9rZT1cIiR7dGhpcy5jb2xvcn1cImApO1xuICAgICAgICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlQWxsKCdzdHJva2U9XCIjN2RlZjdiXCInLCBgc3Ryb2tlPVwiJHt0aGlzLmNvbG9yfVwiYCk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHRoaXMuc3ZnSWNvbiA9IHZhbHVlO1xuICAgICAgICB9KTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgaW1nID0gYDxpbWcgc3JjPVwiaW1hZ2VzL2ljb25zLyR7dGhpcy5uYW1lfS5zdmdcIiBhbHQ9XCIke3RoaXMubmFtZX1cIiAvPmA7XG4gICAgICB0aGlzLnN2Z0ljb24gPSBpbWc7XG4gICAgfVxuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgfVxufVxuIiwiPHNwYW4gKm5nSWY9XCJzdmdJY29uXCIgY2xhc3M9XCJtYXBhX19zdmctaWNvblwiIFtpbm5lckhUTUxdPVwic3ZnSWNvbiB8IHNhZmVIdG1sXCI+PC9zcGFuPiJdfQ==
@@ -0,0 +1,19 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { MapaSvgIconComponent } from "./svg-icon.component";
4
+ import { SafeHtmlPipe } from "./safe-html.pipe";
5
+ import * as i0 from "@angular/core";
6
+ export class MapaSvgIconModule {
7
+ }
8
+ MapaSvgIconModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ MapaSvgIconModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, declarations: [MapaSvgIconComponent, SafeHtmlPipe], imports: [CommonModule], exports: [MapaSvgIconComponent] });
10
+ MapaSvgIconModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, imports: [CommonModule] });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ declarations: [MapaSvgIconComponent, SafeHtmlPipe],
15
+ exports: [MapaSvgIconComponent],
16
+ imports: [CommonModule],
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ZnLWljb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9zdmctaWNvbi9zcmMvc3ZnLWljb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzVELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPaEQsTUFBTSxPQUFPLGlCQUFpQjs7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQUpiLG9CQUFvQixFQUFFLFlBQVksYUFFdkMsWUFBWSxhQURaLG9CQUFvQjtnSEFHbkIsaUJBQWlCLFlBRmxCLFlBQVk7NEZBRVgsaUJBQWlCO2tCQUw3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLG9CQUFvQixFQUFFLFlBQVksQ0FBQztvQkFDbEQsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7b0JBQy9CLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztpQkFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBNYXBhU3ZnSWNvbkNvbXBvbmVudCB9IGZyb20gXCIuL3N2Zy1pY29uLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgU2FmZUh0bWxQaXBlIH0gZnJvbSBcIi4vc2FmZS1odG1sLnBpcGVcIjtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbTWFwYVN2Z0ljb25Db21wb25lbnQsIFNhZmVIdG1sUGlwZV0sXG4gIGV4cG9ydHM6IFtNYXBhU3ZnSWNvbkNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXBhU3ZnSWNvbk1vZHVsZSB7fVxuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './svg-icon';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwYS1saWJyYXJ5LXVpLXNyYy1saWItY29tcG9uZW50cy1zdmctaWNvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hcGEtbGlicmFyeS11aS9zcmMvbWFwYS1saWJyYXJ5LXVpLXNyYy1saWItY29tcG9uZW50cy1zdmctaWNvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3N2Zy1pY29uJztcbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /*
2
+ * Public API Surface of mapa-library-ui svg-icon
3
+ */
4
+ export * from './lib/components/svg-icon/public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ZnLWljb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL3N2Zy1pY29uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxzQ0FBc0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgbWFwYS1saWJyYXJ5LXVpIHN2Zy1pY29uXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9zdmctaWNvbi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,6 @@
1
+ /*
2
+ * Public API Surface of mapa-library-ui svg-icon
3
+ */
4
+ export * from './src/svg-icon.component';
5
+ export * from './src/svg-icon.module';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hcGEtbGlicmFyeS11aS9zcmMvbGliL2NvbXBvbmVudHMvc3ZnLWljb24vcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgbWFwYS1saWJyYXJ5LXVpIHN2Zy1pY29uXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9zcmMvc3ZnLWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3N2Zy1pY29uLm1vZHVsZSc7Il19
@@ -0,0 +1,20 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/platform-browser";
4
+ export class SafeHtmlPipe {
5
+ constructor(sanitized) {
6
+ this.sanitized = sanitized;
7
+ }
8
+ transform(value) {
9
+ return this.sanitized.bypassSecurityTrustHtml(value);
10
+ }
11
+ }
12
+ SafeHtmlPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SafeHtmlPipe, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Pipe });
13
+ SafeHtmlPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: SafeHtmlPipe, name: "safeHtml" });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SafeHtmlPipe, decorators: [{
15
+ type: Pipe,
16
+ args: [{
17
+ name: 'safeHtml',
18
+ }]
19
+ }], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; } });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS1odG1sLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb21wb25lbnRzL3N2Zy1pY29uL3NyYy9zYWZlLWh0bWwucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7O0FBTXBELE1BQU0sT0FBTyxZQUFZO0lBRXZCLFlBQW9CLFNBQXVCO1FBQXZCLGNBQVMsR0FBVCxTQUFTLENBQWM7SUFBRyxDQUFDO0lBRS9DLFNBQVMsQ0FBQyxLQUFhO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2RCxDQUFDOzswR0FOVSxZQUFZO3dHQUFaLFlBQVk7NEZBQVosWUFBWTtrQkFIeEIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsVUFBVTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVIdG1sIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ3NhZmVIdG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgU2FmZUh0bWxQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzYW5pdGl6ZWQ6IERvbVNhbml0aXplcikge31cblxuICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZyk6IFNhZmVIdG1sIHtcbiAgICByZXR1cm4gdGhpcy5zYW5pdGl6ZWQuYnlwYXNzU2VjdXJpdHlUcnVzdEh0bWwodmFsdWUpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,48 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common/http";
4
+ import * as i2 from "@angular/common";
5
+ import * as i3 from "./safe-html.pipe";
6
+ export class MapaSvgIconComponent {
7
+ constructor(httpClient, cdr) {
8
+ this.httpClient = httpClient;
9
+ this.cdr = cdr;
10
+ }
11
+ ngOnChanges() {
12
+ if (!this.name) {
13
+ this.svgIcon = '';
14
+ return;
15
+ }
16
+ if (this.color) {
17
+ this.httpClient
18
+ .get(`images/icons/${this.name}.svg`, { responseType: 'text' })
19
+ .subscribe((value) => {
20
+ if (this.color) {
21
+ value = value.replaceAll('fill="#50575E"', `fill="${this.color}"`);
22
+ value = value.replaceAll('fill="#181818"', `fill="${this.color}"`);
23
+ value = value.replaceAll('fill="#7def7b"', `fill="${this.color}"`);
24
+ value = value.replaceAll('stroke="#50575E"', `stroke="${this.color}"`);
25
+ value = value.replaceAll('stroke="#181818"', `stroke="${this.color}"`);
26
+ value = value.replaceAll('stroke="#7def7b"', `stroke="${this.color}"`);
27
+ }
28
+ this.svgIcon = value;
29
+ });
30
+ }
31
+ else {
32
+ const img = `<img src="images/icons/${this.name}.svg" alt="${this.name}" />`;
33
+ this.svgIcon = img;
34
+ }
35
+ this.cdr.detectChanges();
36
+ }
37
+ }
38
+ MapaSvgIconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconComponent, deps: [{ token: i1.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
39
+ MapaSvgIconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MapaSvgIconComponent, selector: "mapa-svg-icon", inputs: { name: "name", color: "color" }, usesOnChanges: true, ngImport: i0, template: "<span *ngIf=\"svgIcon\" class=\"mapa__svg-icon\" [innerHTML]=\"svgIcon | safeHtml\"></span>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.SafeHtmlPipe, name: "safeHtml" }] });
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconComponent, decorators: [{
41
+ type: Component,
42
+ args: [{ selector: "mapa-svg-icon", template: "<span *ngIf=\"svgIcon\" class=\"mapa__svg-icon\" [innerHTML]=\"svgIcon | safeHtml\"></span>" }]
43
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { name: [{
44
+ type: Input
45
+ }], color: [{
46
+ type: Input
47
+ }] } });
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ZnLWljb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9zdmctaWNvbi9zcmMvc3ZnLWljb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9zdmctaWNvbi9zcmMvc3ZnLWljb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFxQixTQUFTLEVBQUUsS0FBSyxFQUE4QixNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRaEcsTUFBTSxPQUFPLG9CQUFvQjtJQU0vQixZQUFvQixVQUFzQixFQUFVLEdBQXNCO1FBQXRELGVBQVUsR0FBVixVQUFVLENBQVk7UUFBVSxRQUFHLEdBQUgsR0FBRyxDQUFtQjtJQUFJLENBQUM7SUFFeEUsV0FBVztRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNkLElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxDQUFDO1lBQ2xCLE9BQU87U0FDUjtRQUNELElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLElBQUksQ0FBQyxVQUFVO2lCQUNaLEdBQUcsQ0FBQyxnQkFBZ0IsSUFBSSxDQUFDLElBQUksTUFBTSxFQUFFLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxDQUFDO2lCQUM5RCxTQUFTLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRTtnQkFDM0IsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO29CQUNkLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLFNBQVMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ25FLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLFNBQVMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ25FLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLFNBQVMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ25FLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGtCQUFrQixFQUFFLFdBQVcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ3ZFLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGtCQUFrQixFQUFFLFdBQVcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7b0JBQ3ZFLEtBQUssR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLGtCQUFrQixFQUFFLFdBQVcsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7aUJBQ3hFO2dCQUNELElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1lBQ3ZCLENBQUMsQ0FBQyxDQUFDO1NBQ047YUFBTTtZQUNMLE1BQU0sR0FBRyxHQUFHLDBCQUEwQixJQUFJLENBQUMsSUFBSSxjQUFjLElBQUksQ0FBQyxJQUFJLE1BQU0sQ0FBQztZQUM3RSxJQUFJLENBQUMsT0FBTyxHQUFHLEdBQUcsQ0FBQztTQUNwQjtRQUNELElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7a0hBaENVLG9CQUFvQjtzR0FBcEIsb0JBQW9CLG9IQ1JqQyw2RkFBcUY7NEZEUXhFLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxlQUFlO2lJQUtULElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsS0FBSztzQkFBcEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNlY3VyaXR5Q29udGV4dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogXCJtYXBhLXN2Zy1pY29uXCIsXG4gIHRlbXBsYXRlVXJsOiBcIi4vc3ZnLWljb24uY29tcG9uZW50Lmh0bWxcIixcbiAgc3R5bGVVcmxzOiBbXCIuL3N2Zy1pY29uLmNvbXBvbmVudC5zY3NzXCJdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXBhU3ZnSWNvbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIHB1YmxpYyBuYW1lPzogc3RyaW5nO1xuICBASW5wdXQoKSBwdWJsaWMgY29sb3I/OiBzdHJpbmc7XG5cbiAgcHVibGljIHN2Z0ljb246IGFueTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHBDbGllbnQ6IEh0dHBDbGllbnQsIHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikgeyB9XG5cbiAgcHVibGljIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5uYW1lKSB7XG4gICAgICB0aGlzLnN2Z0ljb24gPSAnJztcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgaWYgKHRoaXMuY29sb3IpIHtcbiAgICAgIHRoaXMuaHR0cENsaWVudFxuICAgICAgICAuZ2V0KGBpbWFnZXMvaWNvbnMvJHt0aGlzLm5hbWV9LnN2Z2AsIHsgcmVzcG9uc2VUeXBlOiAndGV4dCcgfSlcbiAgICAgICAgLnN1YnNjcmliZSgodmFsdWU6IHN0cmluZykgPT4ge1xuICAgICAgICAgIGlmICh0aGlzLmNvbG9yKSB7XG4gICAgICAgICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2VBbGwoJ2ZpbGw9XCIjNTA1NzVFXCInLCBgZmlsbD1cIiR7dGhpcy5jb2xvcn1cImApO1xuICAgICAgICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlQWxsKCdmaWxsPVwiIzE4MTgxOFwiJywgYGZpbGw9XCIke3RoaXMuY29sb3J9XCJgKTtcbiAgICAgICAgICAgIHZhbHVlID0gdmFsdWUucmVwbGFjZUFsbCgnZmlsbD1cIiM3ZGVmN2JcIicsIGBmaWxsPVwiJHt0aGlzLmNvbG9yfVwiYCk7XG4gICAgICAgICAgICB2YWx1ZSA9IHZhbHVlLnJlcGxhY2VBbGwoJ3N0cm9rZT1cIiM1MDU3NUVcIicsIGBzdHJva2U9XCIke3RoaXMuY29sb3J9XCJgKTtcbiAgICAgICAgICAgIHZhbHVlID0gdmFsdWUucmVwbGFjZUFsbCgnc3Ryb2tlPVwiIzE4MTgxOFwiJywgYHN0cm9rZT1cIiR7dGhpcy5jb2xvcn1cImApO1xuICAgICAgICAgICAgdmFsdWUgPSB2YWx1ZS5yZXBsYWNlQWxsKCdzdHJva2U9XCIjN2RlZjdiXCInLCBgc3Ryb2tlPVwiJHt0aGlzLmNvbG9yfVwiYCk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHRoaXMuc3ZnSWNvbiA9IHZhbHVlO1xuICAgICAgICB9KTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgaW1nID0gYDxpbWcgc3JjPVwiaW1hZ2VzL2ljb25zLyR7dGhpcy5uYW1lfS5zdmdcIiBhbHQ9XCIke3RoaXMubmFtZX1cIiAvPmA7XG4gICAgICB0aGlzLnN2Z0ljb24gPSBpbWc7XG4gICAgfVxuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgfVxufVxuIiwiPHNwYW4gKm5nSWY9XCJzdmdJY29uXCIgY2xhc3M9XCJtYXBhX19zdmctaWNvblwiIFtpbm5lckhUTUxdPVwic3ZnSWNvbiB8IHNhZmVIdG1sXCI+PC9zcGFuPiJdfQ==
@@ -0,0 +1,19 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { MapaSvgIconComponent } from "./svg-icon.component";
4
+ import { SafeHtmlPipe } from "./safe-html.pipe";
5
+ import * as i0 from "@angular/core";
6
+ export class MapaSvgIconModule {
7
+ }
8
+ MapaSvgIconModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ MapaSvgIconModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, declarations: [MapaSvgIconComponent, SafeHtmlPipe], imports: [CommonModule], exports: [MapaSvgIconComponent] });
10
+ MapaSvgIconModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, imports: [CommonModule] });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MapaSvgIconModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ declarations: [MapaSvgIconComponent, SafeHtmlPipe],
15
+ exports: [MapaSvgIconComponent],
16
+ imports: [CommonModule],
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3ZnLWljb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWFwYS1saWJyYXJ5LXVpL3NyYy9saWIvY29tcG9uZW50cy9zdmctaWNvbi9zcmMvc3ZnLWljb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzVELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPaEQsTUFBTSxPQUFPLGlCQUFpQjs7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQUpiLG9CQUFvQixFQUFFLFlBQVksYUFFdkMsWUFBWSxhQURaLG9CQUFvQjtnSEFHbkIsaUJBQWlCLFlBRmxCLFlBQVk7NEZBRVgsaUJBQWlCO2tCQUw3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLG9CQUFvQixFQUFFLFlBQVksQ0FBQztvQkFDbEQsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7b0JBQy9CLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztpQkFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBNYXBhU3ZnSWNvbkNvbXBvbmVudCB9IGZyb20gXCIuL3N2Zy1pY29uLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgU2FmZUh0bWxQaXBlIH0gZnJvbSBcIi4vc2FmZS1odG1sLnBpcGVcIjtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbTWFwYVN2Z0ljb25Db21wb25lbnQsIFNhZmVIdG1sUGlwZV0sXG4gIGV4cG9ydHM6IFtNYXBhU3ZnSWNvbkNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXBhU3ZnSWNvbk1vZHVsZSB7fVxuIl19