mempool/frontend/src/app/components/search-form/search-form.component.ts

65 lines
2.0 KiB
TypeScript
Raw Normal View History

import { Component, OnInit, ChangeDetectionStrategy, EventEmitter, Output } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { Router } from '@angular/router';
2020-05-02 07:36:35 +02:00
import { environment } from 'src/environments/environment';
import { AssetsService } from 'src/app/services/assets.service';
@Component({
selector: 'app-search-form',
templateUrl: './search-form.component.html',
styleUrls: ['./search-form.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush
})
export class SearchFormComponent implements OnInit {
2020-05-02 07:36:35 +02:00
network = environment.network;
assets: object;
searchForm: FormGroup;
@Output() searchTriggered = new EventEmitter();
regexAddress = /^([a-km-zA-HJ-NP-Z1-9]{26,35}|[a-km-zA-HJ-NP-Z1-9]{80}|[a-z]{2,5}1[ac-hj-np-z02-9]{8,87})$/;
regexBlockhash = /^[0]{8}[a-fA-F0-9]{56}$/;
regexTransaction = /^[a-fA-F0-9]{64}$/;
constructor(
private formBuilder: FormBuilder,
private router: Router,
2020-05-02 07:36:35 +02:00
private assetsService: AssetsService,
) { }
ngOnInit() {
this.searchForm = this.formBuilder.group({
searchText: ['', Validators.required],
});
2020-05-02 07:36:35 +02:00
this.assetsService.assetsMinimal$
.subscribe((assets) => {
this.assets = assets;
});
}
search() {
const searchText = this.searchForm.value.searchText.trim();
if (searchText) {
if (this.regexAddress.test(searchText)) {
this.router.navigate(['/address/', searchText]);
this.searchTriggered.emit();
} else if (this.regexBlockhash.test(searchText)) {
this.router.navigate(['/block/', searchText]);
this.searchTriggered.emit();
} else if (this.regexTransaction.test(searchText)) {
2020-05-02 07:36:35 +02:00
if (this.network === 'liquid' && this.assets[searchText]) {
this.router.navigate(['/asset/', searchText]);
} else {
this.router.navigate(['/tx/', searchText]);
}
this.searchTriggered.emit();
} else {
return;
}
this.searchForm.setValue({
searchText: '',
});
}
}
}