myrta-ui 17.0.14 → 17.0.16

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.
@@ -15,6 +15,7 @@ export class RadioGroupComponent {
15
15
  _isInit = false;
16
16
  _groupItemsWrapperHeight = 0;
17
17
  _searchValue = '';
18
+ _list = [];
18
19
  selectedValue = null;
19
20
  filteredList = [];
20
21
  // SAVE STATE
@@ -41,6 +42,7 @@ export class RadioGroupComponent {
41
42
  // LABEL
42
43
  labelText = '';
43
44
  set items(value) {
45
+ this._list = value;
44
46
  this.filteredList = value;
45
47
  }
46
48
  get items() {
@@ -92,13 +94,14 @@ export class RadioGroupComponent {
92
94
  }
93
95
  updateRadioGroupSearchValue(searchValue) {
94
96
  this._searchValue = searchValue;
95
- this.filteredList = filterSearchGroup(this.items, this._searchValue);
97
+ this.filteredList = filterSearchGroup(this._list, this._searchValue);
96
98
  }
97
99
  radioChanged({ item }) {
98
100
  const cloneList = cloneDeep(this.filteredList);
99
101
  const targetItem = getItemById(cloneList, item.id);
100
102
  this.selectedValue = targetItem;
101
103
  this.filteredList = moveSelectedToFirst(cloneList, this.sortable, targetItem);
104
+ this._list = this.filteredList;
102
105
  this.updateValue(this.filteredList, targetItem);
103
106
  this.modelItemChange.emit(targetItem);
104
107
  }
@@ -181,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
181
184
  }], modelItemChange: [{
182
185
  type: Output
183
186
  }] } });
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/radio-group/radio-group.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/radio-group/radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { InputSearchSizesTypes } from './../input-search/input-search.enum';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Injectable,\r\n  Input,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { RadioGroupItem, RadioGroupValueWithId } from './models/radio-group.model';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { moveSelectedToFirst } from './helpers/move-selected-to-first';\r\nimport { filterSearchGroup } from './helpers/filter-search-group';\r\nimport { getItemById } from './helpers/get-item-by-id';\r\nimport { v4 as uuid } from 'uuid';\r\nimport { Field } from '../../../services/mrx-autosave/mrx-autosave.service';\r\n\r\n@Injectable({\r\n  providedIn: RadioGroupComponent\r\n})\r\n@Component({\r\n  selector: 'mrx-radio-group',\r\n  templateUrl: './radio-group.component.html',\r\n  styleUrls: ['./radio-group.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => RadioGroupComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class RadioGroupComponent implements ControlValueAccessor {\r\n  private _isInit = false;\r\n  private _groupItemsWrapperHeight = 0;\r\n  private _searchValue = '';\r\n\r\n\r\n  public selectedValue: RadioGroupItem | null = null;\r\n  public filteredList: RadioGroupItem[] = [];\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuid();\r\n\r\n  @Input() public fields: Field[] = [];\r\n  @Input() searchSize: InputSearchSizesTypes = 'medium';\r\n  @Input() public name = '';\r\n  @Input() public scrollMaxHeight = 200;\r\n  @Input() public searchable = false;\r\n  @Input() public bold = false;\r\n  @Input() public scrollable = false;\r\n  @Input() public sortable = false;\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public enableMessage = 'Ничего не найдено';\r\n  @Input() public searchPlaceholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public required = false;\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  // TOOLTIP\r\n  @Input() tooltip = '';\r\n\r\n  // LABEL\r\n  @Input() labelText = '';\r\n\r\n  @Input() set items(value: RadioGroupItem[]) {\r\n    this.filteredList = value\r\n  }\r\n\r\n  get items(): RadioGroupItem[] {\r\n    return this.filteredList\r\n  }\r\n\r\n  @ViewChild('groupItemsWrapper') groupItemsWrapper!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<RadioGroupItem | null> = new EventEmitter<RadioGroupItem | null>();\r\n  @Output() public modelChange: EventEmitter<RadioGroupValueWithId> = new EventEmitter<RadioGroupValueWithId>();\r\n  @Output() public modelCheckedChange: EventEmitter<RadioGroupItem | null> = new EventEmitter<RadioGroupItem | null>();\r\n  @Output() public modelItemChange: EventEmitter<RadioGroupItem | null> = new EventEmitter<RadioGroupItem | null>();\r\n\r\n  public get isSearchValue(): string {\r\n    return this._searchValue;\r\n  }\r\n\r\n  public get displaced(): boolean {\r\n    return this.items.some((item: RadioGroupItem) => item.array.length);\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses}`;\r\n  }\r\n\r\n  public get getShowScroll(): boolean {\r\n    return this._groupItemsWrapperHeight > this.scrollMaxHeight;\r\n  }\r\n\r\n  public trackByFn(index: number, item: RadioGroupItem) {\r\n    return item.id;\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public writeValue(selectedValue: RadioGroupItem): void {\r\n    this.selectedValue = selectedValue;\r\n    this._isInit = true;\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public updateValue(list: RadioGroupItem[], targetItem: RadioGroupItem | null): void {\r\n    this.changed.emit(targetItem);\r\n    this.modelChange.emit({value: targetItem, id: this.uuid});\r\n    this.modelCheckedChange.emit(targetItem);\r\n    this.onChange(targetItem);\r\n    this.onTouched();\r\n  }\r\n\r\n  public checkHeightGroupWrapper(): void {\r\n    this._groupItemsWrapperHeight = this.groupItemsWrapper.nativeElement.scrollHeight;\r\n  }\r\n\r\n  public updateRadioGroupSearchValue(searchValue: string): void {\r\n    this._searchValue = searchValue;\r\n    this.filteredList = filterSearchGroup(this.items, this._searchValue);\r\n  }\r\n\r\n  radioChanged({item}: { item: RadioGroupItem }) {\r\n    const cloneList: RadioGroupItem[] = cloneDeep(this.filteredList);\r\n    const targetItem: RadioGroupItem | null = getItemById(cloneList, item.id);\r\n    this.selectedValue = targetItem;\r\n    this.filteredList = moveSelectedToFirst(cloneList, this.sortable, targetItem);\r\n    this.updateValue(this.filteredList, targetItem);\r\n    this.modelItemChange.emit(targetItem);\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage?.length;\r\n  }\r\n}\r\n","<div class=\"mrx-radio-group\" [class]=\"getClasses\">\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\" type=\"radioGroup\"></mrx-save-state>\r\n\r\n    <mrx-radio-group-header\r\n      [searchable]=\"searchable\"\r\n      [searchPlaceholder]=\"searchPlaceholder\"\r\n      [tooltip]=\"tooltip\"\r\n      [required]=\"required\"\r\n      [searchSize]=\"searchSize\"\r\n      [labelText]=\"labelText\"\r\n      (updateradioGroupSearchValue)=\"updateRadioGroupSearchValue($event)\"\r\n    ></mrx-radio-group-header>\r\n\r\n    <div\r\n        #groupItemsWrapper\r\n        *ngIf=\"filteredList?.length; else enableMessageTemplate\"\r\n        class=\"mrx-radio-group-wrapper\"\r\n        [class.mrx-radio-group-wrapper--scrollable]=\"scrollable\"\r\n        [class.--active]=\"getShowScroll\"\r\n        [style.max-height]=\"scrollable ? scrollMaxHeight + 'px' : 'auto'\">\r\n      <mrx-radio-group-item\r\n          *ngFor=\"let item of filteredList; trackBy: trackByFn; let last = last\"\r\n          [displaced]=\"displaced || false\"\r\n          [item]=\"item\"\r\n          [isLast]=\"last\"\r\n          [selectedValue]=\"selectedValue\"\r\n          [name]=\"name\"\r\n          [bold]=\"bold\"\r\n          [invalid]=\"invalid\"\r\n          [disabled]=\"disabled\"\r\n          [readonly]=\"readonly\"\r\n          [animationTrigger]=\"!!isSearchValue\"\r\n          (animationEnd)=\"checkHeightGroupWrapper()\"\r\n          (radioChanged)=\"radioChanged($event)\"\r\n      ></mrx-radio-group-item>\r\n    </div>\r\n\r\n    <ng-template #enableMessageTemplate>\r\n      <p class=\"mrx-radio-group__empty-message py-12px\">{{ enableMessage }}</p>\r\n    </ng-template>\r\n\r\n    <mrx-error-message\r\n      *ngIf=\"invalid && isInvalidMessage\"\r\n      [invalidMessage]=\"invalidMessage\"\r\n      [customClasses]=\"'mt-2'\"\r\n    ></mrx-error-message>\r\n  </div>\r\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/radio-group/radio-group.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/radio-group/radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { InputSearchSizesTypes } from '../input-search/input-search.enum';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Injectable,\r\n  Input,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { RadioGroupItem, RadioGroupValueWithId } from './models/radio-group.model';\r\nimport { cloneDeep } from 'lodash-es';\r\nimport { moveSelectedToFirst } from './helpers/move-selected-to-first';\r\nimport { filterSearchGroup } from './helpers/filter-search-group';\r\nimport { getItemById } from './helpers/get-item-by-id';\r\nimport { v4 as uuid } from 'uuid';\r\nimport { Field } from '../../../services';\r\n\r\n@Injectable({\r\n  providedIn: RadioGroupComponent\r\n})\r\n@Component({\r\n  selector: 'mrx-radio-group',\r\n  templateUrl: './radio-group.component.html',\r\n  styleUrls: ['./radio-group.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => RadioGroupComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class RadioGroupComponent implements ControlValueAccessor {\r\n  private _isInit = false;\r\n  private _groupItemsWrapperHeight = 0;\r\n  private _searchValue = '';\r\n  private _list: RadioGroupItem[] = [];\r\n\r\n\r\n  public selectedValue: RadioGroupItem | null = null;\r\n  public filteredList: RadioGroupItem[] = [];\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuid();\r\n\r\n  @Input() public fields: Field[] = [];\r\n  @Input() searchSize: InputSearchSizesTypes = 'medium';\r\n  @Input() public name = '';\r\n  @Input() public scrollMaxHeight = 200;\r\n  @Input() public searchable = false;\r\n  @Input() public bold = false;\r\n  @Input() public scrollable = false;\r\n  @Input() public sortable = false;\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public enableMessage = 'Ничего не найдено';\r\n  @Input() public searchPlaceholder = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public required = false;\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  // TOOLTIP\r\n  @Input() tooltip = '';\r\n\r\n  // LABEL\r\n  @Input() labelText = '';\r\n\r\n  @Input() set items(value: RadioGroupItem[]) {\r\n    this._list = value\r\n    this.filteredList = value\r\n  }\r\n\r\n  get items(): RadioGroupItem[] {\r\n    return this.filteredList\r\n  }\r\n\r\n  @ViewChild('groupItemsWrapper') groupItemsWrapper!: ElementRef;\r\n\r\n  @Output() public changed: EventEmitter<RadioGroupItem | null> = new EventEmitter<RadioGroupItem | null>();\r\n  @Output() public modelChange: EventEmitter<RadioGroupValueWithId> = new EventEmitter<RadioGroupValueWithId>();\r\n  @Output() public modelCheckedChange: EventEmitter<RadioGroupItem | null> = new EventEmitter<RadioGroupItem | null>();\r\n  @Output() public modelItemChange: EventEmitter<RadioGroupItem | null> = new EventEmitter<RadioGroupItem | null>();\r\n\r\n  public get isSearchValue(): string {\r\n    return this._searchValue;\r\n  }\r\n\r\n  public get displaced(): boolean {\r\n    return this.items.some((item: RadioGroupItem) => item.array.length);\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses}`;\r\n  }\r\n\r\n  public get getShowScroll(): boolean {\r\n    return this._groupItemsWrapperHeight > this.scrollMaxHeight;\r\n  }\r\n\r\n  public trackByFn(index: number, item: RadioGroupItem) {\r\n    return item.id;\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public writeValue(selectedValue: RadioGroupItem): void {\r\n    this.selectedValue = selectedValue;\r\n    this._isInit = true;\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public updateValue(list: RadioGroupItem[], targetItem: RadioGroupItem | null): void {\r\n    this.changed.emit(targetItem);\r\n    this.modelChange.emit({value: targetItem, id: this.uuid});\r\n    this.modelCheckedChange.emit(targetItem);\r\n    this.onChange(targetItem);\r\n    this.onTouched();\r\n  }\r\n\r\n  public checkHeightGroupWrapper(): void {\r\n    this._groupItemsWrapperHeight = this.groupItemsWrapper.nativeElement.scrollHeight;\r\n  }\r\n\r\n  public updateRadioGroupSearchValue(searchValue: string): void {\r\n    this._searchValue = searchValue;\r\n    this.filteredList = filterSearchGroup(this._list, this._searchValue);\r\n  }\r\n\r\n  radioChanged({item}: { item: RadioGroupItem }) {\r\n    const cloneList: RadioGroupItem[] = cloneDeep(this.filteredList);\r\n    const targetItem: RadioGroupItem | null = getItemById(cloneList, item.id);\r\n    this.selectedValue = targetItem;\r\n    this.filteredList = moveSelectedToFirst(cloneList, this.sortable, targetItem);\r\n    this._list = this.filteredList\r\n    this.updateValue(this.filteredList, targetItem);\r\n    this.modelItemChange.emit(targetItem);\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage?.length;\r\n  }\r\n}\r\n","<div class=\"mrx-radio-group\" [class]=\"getClasses\">\r\n    <mrx-save-state [id]=\"uuid\" [fields]=\"fields\" type=\"radioGroup\"></mrx-save-state>\r\n\r\n    <mrx-radio-group-header\r\n      [searchable]=\"searchable\"\r\n      [searchPlaceholder]=\"searchPlaceholder\"\r\n      [tooltip]=\"tooltip\"\r\n      [required]=\"required\"\r\n      [searchSize]=\"searchSize\"\r\n      [labelText]=\"labelText\"\r\n      (updateradioGroupSearchValue)=\"updateRadioGroupSearchValue($event)\"\r\n    ></mrx-radio-group-header>\r\n\r\n    <div\r\n        #groupItemsWrapper\r\n        *ngIf=\"filteredList?.length; else enableMessageTemplate\"\r\n        class=\"mrx-radio-group-wrapper\"\r\n        [class.mrx-radio-group-wrapper--scrollable]=\"scrollable\"\r\n        [class.--active]=\"getShowScroll\"\r\n        [style.max-height]=\"scrollable ? scrollMaxHeight + 'px' : 'auto'\">\r\n      <mrx-radio-group-item\r\n          *ngFor=\"let item of filteredList; trackBy: trackByFn; let last = last\"\r\n          [displaced]=\"displaced || false\"\r\n          [item]=\"item\"\r\n          [isLast]=\"last\"\r\n          [selectedValue]=\"selectedValue\"\r\n          [name]=\"name\"\r\n          [bold]=\"bold\"\r\n          [invalid]=\"invalid\"\r\n          [disabled]=\"disabled\"\r\n          [readonly]=\"readonly\"\r\n          [animationTrigger]=\"!!isSearchValue\"\r\n          (animationEnd)=\"checkHeightGroupWrapper()\"\r\n          (radioChanged)=\"radioChanged($event)\"\r\n      ></mrx-radio-group-item>\r\n    </div>\r\n\r\n    <ng-template #enableMessageTemplate>\r\n      <p class=\"mrx-radio-group__empty-message py-12px\">{{ enableMessage }}</p>\r\n    </ng-template>\r\n\r\n    <mrx-error-message\r\n      *ngIf=\"invalid && isInvalidMessage\"\r\n      [invalidMessage]=\"invalidMessage\"\r\n      [customClasses]=\"'mt-2'\"\r\n    ></mrx-error-message>\r\n  </div>\r\n"]}
@@ -2,10 +2,10 @@ import { getErrorMessageHelper } from '../helpers/get-error-message.helper';
2
2
  export const patternValidation = (value, validations, key, invalidMessages) => {
3
3
  const validation = new RegExp(validations[key]);
4
4
  const result = { isValid: true, message: null };
5
- if (!validation.test(value)) {
5
+ if (value && !validation.test(value)) {
6
6
  result.message = getErrorMessageHelper(key, invalidMessages, validations.messages);
7
7
  result.isValid = false;
8
8
  }
9
9
  return result;
10
10
  };
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0dGVybi52YWxpZGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9zZXJ2aWNlcy9tcngtZm9ybS12YWxpZGF0b3IvdmFsaWRhdGlvbnMvcGF0dGVybi52YWxpZGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRTVFLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQy9CLEtBQWEsRUFDYixXQUE0QixFQUM1QixHQUF3QixFQUN4QixlQUEwQixFQUNvQixFQUFFO0lBRWhELE1BQU0sVUFBVSxHQUFHLElBQUksTUFBTSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQVcsQ0FBQyxDQUFBO0lBQ3pELE1BQU0sTUFBTSxHQUFpRCxFQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBQyxDQUFDO0lBRTVGLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDNUIsTUFBTSxDQUFDLE9BQU8sR0FBRyxxQkFBcUIsQ0FBQyxHQUFHLEVBQUUsZUFBZSxFQUFFLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQTtRQUNsRixNQUFNLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUN6QixDQUFDO0lBRUQsT0FBTyxNQUFNLENBQUE7QUFDZixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJTWVzc2FnZXMsIFZhbGlkYXRpb25zVHlwZSwgVmFsaWRhdGlvblR5cGVzRW51bSB9IGZyb20gJy4uL21vZGVscyc7XHJcbmltcG9ydCB7IGdldEVycm9yTWVzc2FnZUhlbHBlciB9IGZyb20gJy4uL2hlbHBlcnMvZ2V0LWVycm9yLW1lc3NhZ2UuaGVscGVyJztcclxuXHJcbmV4cG9ydCBjb25zdCBwYXR0ZXJuVmFsaWRhdGlvbiA9IChcclxuICB2YWx1ZTogc3RyaW5nLFxyXG4gIHZhbGlkYXRpb25zOiBWYWxpZGF0aW9uc1R5cGUsXHJcbiAga2V5OiBWYWxpZGF0aW9uVHlwZXNFbnVtLFxyXG4gIGludmFsaWRNZXNzYWdlczogSU1lc3NhZ2VzXHJcbik6IHsgaXNWYWxpZDogYm9vbGVhbiwgbWVzc2FnZTogc3RyaW5nIHwgbnVsbCB9ID0+IHtcclxuXHJcbiAgY29uc3QgdmFsaWRhdGlvbiA9IG5ldyBSZWdFeHAodmFsaWRhdGlvbnNba2V5XSBhcyBSZWdFeHApXHJcbiAgY29uc3QgcmVzdWx0OiB7IGlzVmFsaWQ6IGJvb2xlYW4sIG1lc3NhZ2U6IHN0cmluZyB8IG51bGwgfSA9IHtpc1ZhbGlkOiB0cnVlLCBtZXNzYWdlOiBudWxsfTtcclxuXHJcbiAgaWYgKCF2YWxpZGF0aW9uLnRlc3QodmFsdWUpKSB7XHJcbiAgICByZXN1bHQubWVzc2FnZSA9IGdldEVycm9yTWVzc2FnZUhlbHBlcihrZXksIGludmFsaWRNZXNzYWdlcywgdmFsaWRhdGlvbnMubWVzc2FnZXMpXHJcbiAgICByZXN1bHQuaXNWYWxpZCA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgcmV0dXJuIHJlc3VsdFxyXG59O1xyXG4iXX0=
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0dGVybi52YWxpZGF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9zZXJ2aWNlcy9tcngtZm9ybS12YWxpZGF0b3IvdmFsaWRhdGlvbnMvcGF0dGVybi52YWxpZGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRTVFLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQy9CLEtBQWEsRUFDYixXQUE0QixFQUM1QixHQUF3QixFQUN4QixlQUEwQixFQUNvQixFQUFFO0lBRWhELE1BQU0sVUFBVSxHQUFHLElBQUksTUFBTSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQVcsQ0FBQyxDQUFBO0lBQ3pELE1BQU0sTUFBTSxHQUFpRCxFQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBQyxDQUFDO0lBRTVGLElBQUksS0FBSyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ3JDLE1BQU0sQ0FBQyxPQUFPLEdBQUcscUJBQXFCLENBQUMsR0FBRyxFQUFFLGVBQWUsRUFBRSxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUE7UUFDbEYsTUFBTSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDekIsQ0FBQztJQUVELE9BQU8sTUFBTSxDQUFBO0FBQ2YsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSU1lc3NhZ2VzLCBWYWxpZGF0aW9uc1R5cGUsIFZhbGlkYXRpb25UeXBlc0VudW0gfSBmcm9tICcuLi9tb2RlbHMnO1xyXG5pbXBvcnQgeyBnZXRFcnJvck1lc3NhZ2VIZWxwZXIgfSBmcm9tICcuLi9oZWxwZXJzL2dldC1lcnJvci1tZXNzYWdlLmhlbHBlcic7XHJcblxyXG5leHBvcnQgY29uc3QgcGF0dGVyblZhbGlkYXRpb24gPSAoXHJcbiAgdmFsdWU6IHN0cmluZyxcclxuICB2YWxpZGF0aW9uczogVmFsaWRhdGlvbnNUeXBlLFxyXG4gIGtleTogVmFsaWRhdGlvblR5cGVzRW51bSxcclxuICBpbnZhbGlkTWVzc2FnZXM6IElNZXNzYWdlc1xyXG4pOiB7IGlzVmFsaWQ6IGJvb2xlYW4sIG1lc3NhZ2U6IHN0cmluZyB8IG51bGwgfSA9PiB7XHJcblxyXG4gIGNvbnN0IHZhbGlkYXRpb24gPSBuZXcgUmVnRXhwKHZhbGlkYXRpb25zW2tleV0gYXMgUmVnRXhwKVxyXG4gIGNvbnN0IHJlc3VsdDogeyBpc1ZhbGlkOiBib29sZWFuLCBtZXNzYWdlOiBzdHJpbmcgfCBudWxsIH0gPSB7aXNWYWxpZDogdHJ1ZSwgbWVzc2FnZTogbnVsbH07XHJcblxyXG4gIGlmICh2YWx1ZSAmJiAhdmFsaWRhdGlvbi50ZXN0KHZhbHVlKSkge1xyXG4gICAgcmVzdWx0Lm1lc3NhZ2UgPSBnZXRFcnJvck1lc3NhZ2VIZWxwZXIoa2V5LCBpbnZhbGlkTWVzc2FnZXMsIHZhbGlkYXRpb25zLm1lc3NhZ2VzKVxyXG4gICAgcmVzdWx0LmlzVmFsaWQgPSBmYWxzZTtcclxuICB9XHJcblxyXG4gIHJldHVybiByZXN1bHRcclxufTtcclxuIl19
@@ -3437,7 +3437,7 @@ const emailValidation = (value, validations, key, invalidMessages) => {
3437
3437
  const patternValidation = (value, validations, key, invalidMessages) => {
3438
3438
  const validation = new RegExp(validations[key]);
3439
3439
  const result = { isValid: true, message: null };
3440
- if (!validation.test(value)) {
3440
+ if (value && !validation.test(value)) {
3441
3441
  result.message = getErrorMessageHelper(key, invalidMessages, validations.messages);
3442
3442
  result.isValid = false;
3443
3443
  }
@@ -13479,6 +13479,7 @@ class RadioGroupComponent {
13479
13479
  _isInit = false;
13480
13480
  _groupItemsWrapperHeight = 0;
13481
13481
  _searchValue = '';
13482
+ _list = [];
13482
13483
  selectedValue = null;
13483
13484
  filteredList = [];
13484
13485
  // SAVE STATE
@@ -13505,6 +13506,7 @@ class RadioGroupComponent {
13505
13506
  // LABEL
13506
13507
  labelText = '';
13507
13508
  set items(value) {
13509
+ this._list = value;
13508
13510
  this.filteredList = value;
13509
13511
  }
13510
13512
  get items() {
@@ -13556,13 +13558,14 @@ class RadioGroupComponent {
13556
13558
  }
13557
13559
  updateRadioGroupSearchValue(searchValue) {
13558
13560
  this._searchValue = searchValue;
13559
- this.filteredList = filterSearchGroup(this.items, this._searchValue);
13561
+ this.filteredList = filterSearchGroup(this._list, this._searchValue);
13560
13562
  }
13561
13563
  radioChanged({ item }) {
13562
13564
  const cloneList = cloneDeep(this.filteredList);
13563
13565
  const targetItem = getItemById(cloneList, item.id);
13564
13566
  this.selectedValue = targetItem;
13565
13567
  this.filteredList = moveSelectedToFirst(cloneList, this.sortable, targetItem);
13568
+ this._list = this.filteredList;
13566
13569
  this.updateValue(this.filteredList, targetItem);
13567
13570
  this.modelItemChange.emit(targetItem);
13568
13571
  }