Skip to content

Instantly share code, notes, and snippets.

@AlexanderKozhevin
Created May 7, 2017 10:48
Show Gist options
  • Save AlexanderKozhevin/d29741ea3ac604905892cc45a99e569d to your computer and use it in GitHub Desktop.
Save AlexanderKozhevin/d29741ea3ac604905892cc45a99e569d to your computer and use it in GitHub Desktop.
<p>A typeahead example that uses a formatter function for string results</p>
<label for="typeahead-format">Search for a state:</label>
<input id="typeahead-format" type="text" class="form-control" [(ngModel)]="model" [ngbTypeahead]="search" [resultFormatter]="formatter" />
<hr>
<pre>Model: {{ model | json }}</pre>
const states = ['Alabama', 'Alaska', 'American Samoa', 'Arizona', 'Arkansas', 'California', 'Colorado',
'Connecticut', 'Delaware', 'District Of Columbia', 'Federated States Of Micronesia', 'Florida', 'Georgia',
'Guam', 'Hawaii', 'Idaho', 'Illinois', 'Indiana', 'Iowa', 'Kansas', 'Kentucky', 'Louisiana', 'Maine',
'Marshall Islands', 'Maryland', 'Massachusetts', 'Michigan', 'Minnesota', 'Mississippi', 'Missouri', 'Montana',
'Nebraska', 'Nevada', 'New Hampshire', 'New Jersey', 'New Mexico', 'New York', 'North Carolina', 'North Dakota',
'Northern Mariana Islands', 'Ohio', 'Oklahoma', 'Oregon', 'Palau', 'Pennsylvania', 'Puerto Rico', 'Rhode Island',
'South Carolina', 'South Dakota', 'Tennessee', 'Texas', 'Utah', 'Vermont', 'Virgin Islands', 'Virginia',
'Washington', 'West Virginia', 'Wisconsin', 'Wyoming'];
@Component({
selector: 'ngbd-typeahead-format',
templateUrl: './typeahead-format.html',
styles: [`.form-control { width: 300px; }`]
})
export class NgbdTypeaheadFormat {
public model: any;
formatter = (result: string) => result.toUpperCase();
search = (text$: Observable<string>) =>
text$
.debounceTime(200)
.distinctUntilChanged()
.map(term => term === '' ? []
: states.filter(v => new RegExp(term, 'gi').test(v)).slice(0, 10));
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment