Browse Source

web-ui: Allow to find blocks by number

scalafmt-draft
Alexis Hernandez 7 years ago
parent
commit
473002b003
  1. 2
      web-ui/src/app/app.component.ts
  2. 12
      web-ui/src/app/components/finder/finder.component.ts

2
web-ui/src/app/app.component.ts

@ -57,7 +57,7 @@ export class AppComponent {
// labels // labels
'label.coinName': 'XSN', 'label.coinName': 'XSN',
'label.searchField': 'Transaction id, Blockhash, Address, IP address', 'label.searchField': 'Transaction id, Blockhash, Block number, Address, IP address',
'label.transactionId': 'Transaction Id', 'label.transactionId': 'Transaction Id',
'label.confirmations': 'Confirmations', 'label.confirmations': 'Confirmations',
'label.blockhash': 'Block Hash', 'label.blockhash': 'Block Hash',

12
web-ui/src/app/components/finder/finder.component.ts

@ -12,6 +12,7 @@ import { TransactionsService } from '../../services/transactions.service';
import { MasternodesService } from '../../services/masternodes.service'; import { MasternodesService } from '../../services/masternodes.service';
const BLOCK_REGEX = '^[A-Fa-f0-9]{64}$'; const BLOCK_REGEX = '^[A-Fa-f0-9]{64}$';
const BLOCK_NUMBER_REGEX = '^(\\d{1,10})$';
const ADDRESS_REGEX = '^[a-zA-Z0-9]{34}$'; const ADDRESS_REGEX = '^[a-zA-Z0-9]{34}$';
const IP_ADDRESS_REGEX = '^(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})$'; const IP_ADDRESS_REGEX = '^(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})$';
@ -41,8 +42,9 @@ export class FinderComponent implements OnInit {
} }
private createForm() { private createForm() {
const pattern = `(${ADDRESS_REGEX})|(${BLOCK_REGEX})|(${IP_ADDRESS_REGEX})|(${BLOCK_NUMBER_REGEX})`;
this.form = this.formBuilder.group({ this.form = this.formBuilder.group({
searchField: [null, [Validators.required, Validators.pattern(`(${ADDRESS_REGEX})|(${BLOCK_REGEX})|(${IP_ADDRESS_REGEX})`)]], searchField: [null, [Validators.required, Validators.pattern(pattern)]],
}); });
} }
@ -70,13 +72,15 @@ export class FinderComponent implements OnInit {
response => this.navigatorService.masternodeDetails(searchField), response => this.navigatorService.masternodeDetails(searchField),
response => this.onNothingFound() response => this.onNothingFound()
); );
} else if (new RegExp(BLOCK_NUMBER_REGEX).test(searchField)) {
this.lookForBlock(searchField);
} }
} }
private lookForBlock(blockhash: string) { private lookForBlock(query: string) {
this.blocksService.get(blockhash) this.blocksService.get(query)
.subscribe( .subscribe(
response => this.navigatorService.blockDetails(blockhash), response => this.navigatorService.blockDetails(query),
response => this.onNothingFound() response => this.onNothingFound()
); );
} }

Loading…
Cancel
Save