Socket Live data

This commit is contained in:
root 2019-08-08 11:50:39 +05:30
parent e6ce38970f
commit 395ebd9272
9 changed files with 221 additions and 12 deletions

View File

@ -9,8 +9,7 @@ export async function universalGetLatestBlockDetails(socket) {
letest_block_duration = ""; letest_block_duration = "";
const BlockchainLatestBlockQuery = await getConnection().query( const BlockchainLatestBlockQuery = await getConnection().query(
"SELECT timestamp,height,edge_bits,hash,secondary_scaling, previous_id, total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block ORDER BY timestamp DESC LIMIT 1" "SELECT bb.timestamp,bb.proof,bb.height,bb.edge_bits,bb.hash,bb.secondary_scaling, bb.previous_id, bb.total_difficulty_cuckaroo, bb.total_difficulty_cuckatoo, bb.total_difficulty_progpow, bb.total_difficulty_randomx, COUNT(DISTINCT(bi.block_id)) AS input_count, COUNT(DISTINCT(bk.block_id)) AS kernel_count, COUNT(DISTINCT(bo.block_id)) AS output_count FROM blockchain_block bb LEFT JOIN blockchain_input bi ON bi.block_id = bb.hash LEFT JOIN blockchain_kernel bk ON bk.block_id = bb.hash LEFT JOIN blockchain_output bo ON bo.block_id = bb.hash group by bb.hash, bb.timestamp ORDER BY bb.timestamp DESC LIMIT 1");
);
const BlockchainPreviousBlockQuery = await getConnection().query( const BlockchainPreviousBlockQuery = await getConnection().query(
"SELECT total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block WHERE hash=" + "SELECT total_difficulty_cuckaroo, total_difficulty_cuckatoo, total_difficulty_progpow, total_difficulty_randomx FROM blockchain_block WHERE hash=" +
"'" + "'" +
@ -132,10 +131,58 @@ export async function universalGetLatestBlockDetails(socket) {
BlockchainPreviousBlockQuery[0].total_difficulty_randomx; BlockchainPreviousBlockQuery[0].total_difficulty_randomx;
} }
if(BlockchainLatestBlockQuery[0].proof == "RandomX"){
var Difficulty = targetdifficultyrandomx;
}else if(BlockchainLatestBlockQuery[0].proof == "ProgPow"){
var Difficulty = targetdifficultyprogpow;
}else if(BlockchainLatestBlockQuery[0].proof == "Cuckoo" ){
var Difficulty = targetdifficultycuckatoo;
}
block_height = BlockchainLatestBlockQuery[0].height; block_height = BlockchainLatestBlockQuery[0].height;
var current_date = new Date();
// var current_date = new Date("Sat Apr 2 2018 15:04:00 GMT+0530 (IST)");
var enddaydif =
Math.abs(
BlockchainLatestBlockQuery[0].timestamp.getTime() -
current_date.getTime(),
) /
(1000 * 60 * 60 * 24);
var enddayrnd = Math.round(enddaydif);
// if(enddayrnd < 1) {
var millseconds = Math.abs(
BlockchainLatestBlockQuery[0].timestamp.getTime() -
current_date.getTime(),
);
var seconds = Math.floor(millseconds / 1000);
var days = Math.floor(seconds / 86400);
var hours = Math.floor((seconds % 86400) / 3600);
var minutes = Math.floor(((seconds % 86400) % 3600) / 60);
seconds = seconds % 60;
var dateTimeDurationString = '';
if (days > 0 && (hours === 0 && minutes === 0))
dateTimeDurationString += days > 1 ? days + 'd ' : days + 'd ';
if (days > 0 && (hours > 0 || minutes > 0))
dateTimeDurationString += days > 1 ? days + 'd ' : days + 'd ';
if (hours > 0 && minutes > 0)
dateTimeDurationString += hours > 1 ? hours + 'h ' : hours + 'h ';
if (hours > 0 && minutes === 0)
dateTimeDurationString += hours > 1 ? hours + 'h ' : hours + 'h ';
if (minutes > 0)
dateTimeDurationString += minutes > 1 ? minutes + 'm ' : minutes + 'm ';
if (seconds > 0)
dateTimeDurationString += seconds > 1 ? seconds + 's ' : seconds + 's ';
var TotalCuckoo = var TotalCuckoo =
parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo) + parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckatoo) +
parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo); parseInt(BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo);
let balance = BlockchainLatestBlockQuery[0].hash.substring(2, 62);
let arr = balance.match(/.{1,6}/g);
var hasharray = arr.map(i => '#' + i);
socket.emit("latestblockdetail", { socket.emit("latestblockdetail", {
block_height, block_height,
@ -149,6 +196,15 @@ export async function universalGetLatestBlockDetails(socket) {
targetdifficultyprogpow, targetdifficultyprogpow,
targetdifficultyrandomx, targetdifficultyrandomx,
TotalCuckoo, TotalCuckoo,
age : dateTimeDurationString,
input_count: BlockchainLatestBlockQuery[0].input_count,
kernal_count: BlockchainLatestBlockQuery[0].kernal_count,
output_count: BlockchainLatestBlockQuery[0].output_count,
proof: BlockchainLatestBlockQuery[0].proof,
hasharray: hasharray,
Difficulty: Difficulty,
hashstart:BlockchainLatestBlockQuery[0].hash.slice(0, 2),
hashend:BlockchainLatestBlockQuery[0].hash.slice(62,64),
TotalDifficultyCuckaroo: TotalDifficultyCuckaroo:
BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo, BlockchainLatestBlockQuery[0].total_difficulty_cuckaroo,
TotalDifficultyCuckatoo: TotalDifficultyCuckatoo:

View File

@ -0,0 +1,12 @@
@keyframes MyAnimation {
0% {
margin-top: -50px;
}
100% {
margin-top: 0px;
}
}
.my-animation {
animation: MyAnimation 2s;
}

View File

@ -0,0 +1,37 @@
<div [ngClass]="{'mobile_table alt_color' : true, hght_40: item.id != clickValue }" id="hash_{{blockdetails.blockchain_block_height}}" #item >
<div class="my-animation">
<div class="row">
<div class="col-6 col-md-3 tble_col">
<div class="block_div"> <span *ngIf="item.id != clickValue" (click)="onClickPlus(blockdetails.blockchain_block_height);" class="expnd_blck"><i class="fa fa-plus"></i></span>
<span *ngIf="item.id == clickValue" (click)="onClickMinus(blockdetails.blockchain_block_height);" class="expnd_blck"><i class="fa fa-minus"></i></span><h6>Height</h6><span class="blck_value link_to_detail" routerLink="/blockdetail/{{ blockdetails.blockchain_block_height }}">{{ blockdetails.blockchain_block_height }}</span></div>
</div>
<div class="col-6 col-md-3 tble_col">
<div [title]="blockdetails.blockchain_block_hash" routerLink="/blockdetail/{{ blockdetails.blockchain_block_hash }}" class="block_div link_to_detail"><h6>Hash</h6><span class="blck_value">{{ blockdetails.hashstart
}}<span
*ngFor="let color of blockdetails.hasharray"
class="hash"
[ngStyle]="{ 'background-color': color }"
></span
>{{ blockdetails.hashend }}</span></div>
</div>
<div class="col-6 col-md-3 tble_col">
<div class="block_div"><h6 >Age</h6><span class="blck_value">{{ blockdetails.age }}</span></div>
</div>
<div class="col-6 col-md-3 tble_col">
<div class="block_div"><h6>Difficulty</h6><span class="blck_value">{{ blockdetails.target_difficulty | number }}</span></div>
</div>
<div class="col-6 col-sm-6 col-md-3 tble_col">
<div class="block_div"><h6 class="mb-0">Pow Algo</h6><span class="blck_value">{{ blockdetails.PoWAlgo }}</span></div>
</div>
<div class="col-6 col-sm-6 col-md-3 tble_col">
<div class="block_div"><h6>#Inputs</h6><span class="blck_value">{{ blockdetails.input_count }}</span></div>
</div>
<div class="col-6 col-md-3 tble_col">
<div class="block_div"><h6 >#Outputs</h6><span class="blck_value">{{ blockdetails.output_count }}</span></div>
</div>
<div class="col-6 col-md-3 tble_col">
<div class="block_div" ><h6>#Kernels</h6><span class="blck_value">{{ blockdetails.kernal_count }}</span></div>
</div>
</div>
</div>
</div>

View File

@ -0,0 +1,24 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { BlockAppendComponent } from './block-append.component';
describe('BlockAppendComponent', () => {
let component: BlockAppendComponent;
let fixture: ComponentFixture<BlockAppendComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [BlockAppendComponent],
}).compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(BlockAppendComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

View File

@ -0,0 +1,26 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-block-append',
templateUrl: './block-append.component.html',
styleUrls: ['./block-append.component.css'],
})
export class BlockAppendComponent implements OnInit {
public blockdetails: any;
public clickValue: any;
constructor() {}
ngOnInit() {
console.log(this.blockdetails);
}
public onClickPlus(height) {
// this.beforeClick = true;
this.clickValue = 'hash_' + height;
}
public onClickMinus(height) {
this.clickValue = 0;
}
}

View File

@ -7,6 +7,7 @@ import { GraphListComponent } from './graph-list/graph-list.component';
import { BlockDetailListComponent } from './block-detail-list/block-detail-list.component'; import { BlockDetailListComponent } from './block-detail-list/block-detail-list.component';
import { FormsModule, ReactiveFormsModule } from '@angular/forms'; import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { SharedModule } from '../../shared/shared.module'; import { SharedModule } from '../../shared/shared.module';
import { BlockAppendComponent } from './block-append/block-append.component';
import { HttpClientModule, HttpClient, HttpParams } from '@angular/common/http'; import { HttpClientModule, HttpClient, HttpParams } from '@angular/common/http';
import { CookieService } from 'ngx-cookie-service'; import { CookieService } from 'ngx-cookie-service';
@ -22,6 +23,7 @@ import { CustomLoader } from 'src/app/app.module';
LatestblocksComponent, LatestblocksComponent,
GraphListComponent, GraphListComponent,
BlockDetailListComponent, BlockDetailListComponent,
BlockAppendComponent
], ],
imports: [ imports: [
CommonModule, CommonModule,
@ -33,6 +35,7 @@ import { CustomLoader } from 'src/app/app.module';
loader: {provide: TranslateLoader, useClass: CustomLoader, deps : [HttpClient]}, loader: {provide: TranslateLoader, useClass: CustomLoader, deps : [HttpClient]},
}) })
], ],
entryComponents: [BlockAppendComponent],
providers: [TransServiceService,CookieService,ChartService], providers: [TransServiceService,CookieService,ChartService],
}) })
export class HomeModule {} export class HomeModule {}

View File

@ -45,6 +45,7 @@
</div> </div>
</div> </div>
</div> </div>
<div #block></div>
<div [ngClass]="{mobile_table : true, hght_40: item.id != clickValue }" <div [ngClass]="{mobile_table : true, hght_40: item.id != clickValue }"
id="hash_{{hashvalue.blockchain_block_height}}" #item *ngFor="let hashvalue of hashvalues"> id="hash_{{hashvalue.blockchain_block_height}}" #item *ngFor="let hashvalue of hashvalues">

View File

@ -1,10 +1,11 @@
import { Component, OnInit } from '@angular/core'; import { Component, OnInit, ViewContainerRef, ViewChild,ComponentFactoryResolver} from '@angular/core';
import { HttpClient, HttpParams, HttpErrorResponse, HttpHeaders } from '@angular/common/http'; import { HttpClient, HttpParams, HttpErrorResponse, HttpHeaders } from '@angular/common/http';
import { ChartService } from '../../../shared/services/chart.service'; import { ChartService } from '../../../shared/services/chart.service';
import { FormGroup, FormControl } from '@angular/forms'; import { FormGroup, FormControl } from '@angular/forms';
import { TransServiceService } from '../../../shared/services/trans-service.service'; import { TransServiceService } from '../../../shared/services/trans-service.service';
import { map, catchError } from 'rxjs/operators'; import { map, catchError } from 'rxjs/operators';
import { throwError} from 'rxjs'; import { throwError} from 'rxjs';
import { BlockAppendComponent } from '../block-append/block-append.component';
@Component({ @Component({
selector: 'epic-explorer-latestblocks', selector: 'epic-explorer-latestblocks',
@ -14,6 +15,9 @@ import { throwError} from 'rxjs';
export class LatestblocksComponent implements OnInit { export class LatestblocksComponent implements OnInit {
public hashvalues: any; public hashvalues: any;
public pagedata: any = []; public pagedata: any = [];
public blockAppend: any;
public blockdetails: any;
public lastblock: any;
public clickValue: any; public clickValue: any;
public clickPeer: any; public clickPeer: any;
public beforeClick: boolean = false; public beforeClick: boolean = false;
@ -24,11 +28,15 @@ export class LatestblocksComponent implements OnInit {
pagesize: new FormControl(20), pagesize: new FormControl(20),
}); });
constructor(private chartService: ChartService,public translate: TransServiceService,public http: HttpClient) {} @ViewChild('block', { read: ViewContainerRef,static: true }) block: ViewContainerRef;
constructor(private chartService: ChartService,public translate: TransServiceService,public http: HttpClient, private resolver: ComponentFactoryResolver) {}
ngOnInit() { ngOnInit() {
this. getpeersList(); this. getpeersList();
this.gettinghashList(1, 20); this.gettinghashList(1, 20);
this.getLastCeatedBlock();
} }
public gettinghashList(CurrentPage, PageSize) { public gettinghashList(CurrentPage, PageSize) {
@ -46,6 +54,41 @@ export class LatestblocksComponent implements OnInit {
); );
} }
getLastCeatedBlock() {
this.chartService.getLatestblockdetails().subscribe(response => {
this.blockdetails = response;
console.log(this.blockdetails);
if (this.lastblock != this.blockdetails.block_height) {
console.log('Create');
this.createBlock();
}
this.lastblock = this.blockdetails.block_height;
});
}
public createBlock() {
const blockFactory = this.resolver.resolveComponentFactory(
BlockAppendComponent,
);
const block = this.block.createComponent(blockFactory);
this.blockAppend = {};
this.blockAppend['blockchain_block_hash'] = this.blockdetails.hash;
this.blockAppend[
'blockchain_block_height'
] = this.blockdetails.block_height;
this.blockAppend['age'] = this.blockdetails.age;
this.blockAppend['target_difficulty'] = this.blockdetails.Difficulty;
this.blockAppend['PoWAlgo'] = this.blockdetails.proof;
this.blockAppend['input_count'] = this.blockdetails.input_count;
this.blockAppend['output_count'] = this.blockdetails.output_count;
this.blockAppend['kernal_count'] = this.blockdetails.kernel_count;
this.blockAppend['hashstart'] = this.blockdetails.hashstart;
this.blockAppend['hashend'] = this.blockdetails.hashend;
this.blockAppend['hasharray'] = this.blockdetails.hasharray;
block.instance.blockdetails = this.blockAppend;
}
public getpeersList() { public getpeersList() {
this.chartService.apiGetRequest('','/blockchain_kernel/getpeers').subscribe( this.chartService.apiGetRequest('','/blockchain_kernel/getpeers').subscribe(
res => { res => {

View File

@ -645,7 +645,14 @@ body.dark_theme {
.dark_theme .view_content table{border-color: #384566;} .dark_theme .view_content table{border-color: #384566;}
.dark_theme .card-body{background-color: #1c2437;} .dark_theme .card-body{background-color: #1c2437;}
.diff_margin{margin-bottom: -10px !important; margin-top: -10px !important;} .diff_margin{margin-bottom: -10px !important; margin-top: -10px !important;}
@keyframes yellowfade {
from {
background: yellow;
}
to {
background: transparent;
}
}
.item-highlight { .item-highlight {
animation: yellowfade 5s ; animation: yellowfade 5s ;
-moz-animation: yellowfade 5s ; -moz-animation: yellowfade 5s ;