Skip to content

Commit

Permalink
fix(entity-table): fix edition autocomplete (#1098)
Browse files Browse the repository at this point in the history
  • Loading branch information
PhilippeLafreniere18 authored and cbourget committed Mar 21, 2023
1 parent f786f46 commit a1c6e85
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 23 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -93,14 +93,16 @@
{{ option.value }}
</mat-option>
</mat-select>
<input matInput type="text" [formControlName]="column.name" *ngIf="column.type === 'autocomplete'"
[matAutocomplete]="auto" required="{{getValidationAttributeValue(column, 'mandatory')}}" value="{{getValue(record, column)}}">
<mat-autocomplete #auto="matAutocomplete" (optionSelected)="onAutocompleteValueChange(column.name, record, $event)"
panelWidth="430px">
<mat-option *ngFor="let option of filteredOptions | async" [value]="option.id">
{{ option.value }}
</mat-option>
</mat-autocomplete>
<input matInput type="text" [formControlName]="column.name" *ngIf="column.type === 'autocomplete'" [matAutocomplete]="auto"
required="{{getValidationAttributeValue(column, 'mandatory')}}" value="{{getValue(record, column)}}"
readonly="{{getValidationAttributeValue(column, 'readonly')}}">
<mat-autocomplete #auto="matAutocomplete" (optionSelected)="onAutocompleteValueChange(column, record, $event)"
panelWidth="430px">
<mat-option *ngFor="let option of filteredOptions[column.name] | async"
[value]="option.id">
{{ option.value }}
</mat-option>
</mat-autocomplete>
</td>
<ng-template #isUnsanitizedHTML>
<td mat-cell class="mat-cell-text" *ngIf="!isUrl(getValue(record, column));else isAnUrlUnsanitizedHTML" [ngClass]="getCellClass(record, column)"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ export class EntityTableComponent implements OnInit, OnChanges, OnDestroy {

public formGroup: UntypedFormGroup = new UntypedFormGroup({});

public filteredOptions: Observable<any[]>;
public filteredOptions = {};

/**
* Reference to the column renderer types
Expand Down Expand Up @@ -256,9 +256,9 @@ export class EntityTableComponent implements OnInit, OnChanges, OnDestroy {
/**
* Process autocomplete value change (edition)
*/
onAutocompleteValueChange(column: string, record: EntityRecord<any>, event) {
this.formGroup.controls[column].setValue(event.option.viewValue);
const key = this.getColumnKeyWithoutPropertiesTag(column);
onAutocompleteValueChange(column: EntityTableColumn, record: EntityRecord<any>, event) {
this.formGroup.controls[column.name].setValue(event.option.viewValue);
const key = this.getColumnKeyWithoutPropertiesTag(column.name);
record.entity.properties[key] = event.option.value;
}

Expand Down Expand Up @@ -310,17 +310,19 @@ export class EntityTableComponent implements OnInit, OnChanges, OnDestroy {
item[key]
));

this.filteredOptions = this.formGroup.controls[column.name].valueChanges.pipe(
map(value => {
if (value.length) {
return column.domainValues.filter((option) => {
const filterNormalized = value ? value.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '') : '';
const featureNameNormalized = option.value.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '');
return featureNameNormalized.includes(filterNormalized);
});
}
})
);
this.filteredOptions[column.name] = new Observable<any[]>();
this.filteredOptions[column.name] =
this.formGroup.controls[column.name].valueChanges.pipe(
map(value => {
if (value?.length) {
return column.domainValues?.filter((option) => {
const filterNormalized = value ? value.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '') : '';
const featureNameNormalized = option.value.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '');
return featureNameNormalized.includes(filterNormalized);
});
}
})
);

let formControlValue = item[key];
column.domainValues.forEach(option => {
Expand Down

0 comments on commit a1c6e85

Please sign in to comment.