mirror of
https://github.com/everoddandeven/monerod-gui.git
synced 2025-01-24 19:45:52 +00:00
Refactory
This commit is contained in:
parent
80e8a283f4
commit
ba8b471958
9 changed files with 147 additions and 39 deletions
|
@ -12,7 +12,7 @@
|
||||||
|
|
||||||
@for(card of cards; track card.header) {
|
@for(card of cards; track card.header) {
|
||||||
<div class="card text-bg-dark m-3 text-center" style="max-width: 18rem;">
|
<div class="card text-bg-dark m-3 text-center" style="max-width: 18rem;">
|
||||||
<div class="card-header">{{card.header}}</div>
|
<div class="card-header"><strong>{{card.header}}</strong></div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h5 class="card-title">{{card.content}}</h5>
|
<h5 class="card-title">{{card.content}}</h5>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<div class="tab-content" id="pills-tabContent">
|
<div *ngIf="!coreBusy" class="tab-content" id="pills-tabContent">
|
||||||
<div class="tab-pane fade show active" id="pills-miner-data" role="tabpanel" aria-labelledby="pills-miner-data-tab" tabindex="0">
|
<div class="tab-pane fade show active" id="pills-miner-data" role="tabpanel" aria-labelledby="pills-miner-data-tab" tabindex="0">
|
||||||
<div class="row d-flex">
|
<div class="row d-flex">
|
||||||
|
|
||||||
|
@ -51,3 +51,19 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="tab-pane fade" id="pills-disabled" role="tabpanel" aria-labelledby="pills-disabled-tab" tabindex="0">...</div>
|
<div class="tab-pane fade" id="pills-disabled" role="tabpanel" aria-labelledby="pills-disabled-tab" tabindex="0">...</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div *ngIf="coreBusy" class="cover-container d-flex w-100 h-100 p-3 mx-auto flex-column text-center">
|
||||||
|
|
||||||
|
<main class="px-3">
|
||||||
|
<h1>Core is busy.</h1>
|
||||||
|
<p class="lead">Mining capabilities are not available during daemon sync.</p>
|
||||||
|
<p class="lead">
|
||||||
|
<a href="#" class="btn btn-lg btn-light fw-bold border-white bg-white">Learn more</a>
|
||||||
|
</p>
|
||||||
|
</main>
|
||||||
|
<!--
|
||||||
|
<footer class="mt-auto text-white-50">
|
||||||
|
<p>Cover template for <a href="https://getbootstrap.com/" class="text-white">Bootstrap</a>, by <a href="https://twitter.com/mdo" class="text-white">mdo</a>.</p>
|
||||||
|
</footer>
|
||||||
|
-->
|
||||||
|
</div>
|
|
@ -0,0 +1,76 @@
|
||||||
|
.bd-placeholder-img {
|
||||||
|
font-size: 1.125rem;
|
||||||
|
text-anchor: middle;
|
||||||
|
-webkit-user-select: none;
|
||||||
|
-moz-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.bd-placeholder-img-lg {
|
||||||
|
font-size: 3.5rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.b-example-divider {
|
||||||
|
width: 100%;
|
||||||
|
height: 3rem;
|
||||||
|
background-color: rgba(0, 0, 0, .1);
|
||||||
|
border: solid rgba(0, 0, 0, .15);
|
||||||
|
border-width: 1px 0;
|
||||||
|
box-shadow: inset 0 .5em 1.5em rgba(0, 0, 0, .1), inset 0 .125em .5em rgba(0, 0, 0, .15);
|
||||||
|
}
|
||||||
|
|
||||||
|
.b-example-vr {
|
||||||
|
flex-shrink: 0;
|
||||||
|
width: 1.5rem;
|
||||||
|
height: 100vh;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bi {
|
||||||
|
vertical-align: -.125em;
|
||||||
|
fill: currentColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-scroller {
|
||||||
|
position: relative;
|
||||||
|
z-index: 2;
|
||||||
|
height: 2.75rem;
|
||||||
|
overflow-y: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-scroller .nav {
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: nowrap;
|
||||||
|
padding-bottom: 1rem;
|
||||||
|
margin-top: -1px;
|
||||||
|
overflow-x: auto;
|
||||||
|
text-align: center;
|
||||||
|
white-space: nowrap;
|
||||||
|
-webkit-overflow-scrolling: touch;
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn-bd-primary {
|
||||||
|
--bd-violet-bg: #712cf9;
|
||||||
|
--bd-violet-rgb: 112.520718, 44.062154, 249.437846;
|
||||||
|
|
||||||
|
--bs-btn-font-weight: 600;
|
||||||
|
--bs-btn-color: var(--bs-white);
|
||||||
|
--bs-btn-bg: var(--bd-violet-bg);
|
||||||
|
--bs-btn-border-color: var(--bd-violet-bg);
|
||||||
|
--bs-btn-hover-color: var(--bs-white);
|
||||||
|
--bs-btn-hover-bg: #6528e0;
|
||||||
|
--bs-btn-hover-border-color: #6528e0;
|
||||||
|
--bs-btn-focus-shadow-rgb: var(--bd-violet-rgb);
|
||||||
|
--bs-btn-active-color: var(--bs-btn-hover-color);
|
||||||
|
--bs-btn-active-bg: #5a23c8;
|
||||||
|
--bs-btn-active-border-color: #5a23c8;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bd-mode-toggle {
|
||||||
|
z-index: 1500;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bd-mode-toggle .dropdown-menu .active .bi {
|
||||||
|
display: block !important;
|
||||||
|
}
|
|
@ -7,6 +7,7 @@ import { NavbarLink } from '../navbar/navbar.model';
|
||||||
import { MineableTxBacklog } from '../../common/MineableTxBacklog';
|
import { MineableTxBacklog } from '../../common/MineableTxBacklog';
|
||||||
import { Chain } from '../../common/Chain';
|
import { Chain } from '../../common/Chain';
|
||||||
import { CoreIsBusyError } from '../../common/error';
|
import { CoreIsBusyError } from '../../common/error';
|
||||||
|
import { CommonModule, NgIf } from '@angular/common';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-mining',
|
selector: 'app-mining',
|
||||||
|
@ -16,7 +17,7 @@ import { CoreIsBusyError } from '../../common/error';
|
||||||
export class MiningComponent implements AfterViewInit {
|
export class MiningComponent implements AfterViewInit {
|
||||||
|
|
||||||
private readonly navbarLinks: NavbarLink[];
|
private readonly navbarLinks: NavbarLink[];
|
||||||
private coreBusy: boolean;
|
public coreBusy: boolean;
|
||||||
private minerData?: MinerData;
|
private minerData?: MinerData;
|
||||||
|
|
||||||
private majorVersion: number;
|
private majorVersion: number;
|
||||||
|
|
|
@ -2,13 +2,15 @@ import { NgModule } from '@angular/core';
|
||||||
import { CommonModule } from '@angular/common';
|
import { CommonModule } from '@angular/common';
|
||||||
|
|
||||||
import { MiningRoutingModule } from './mining-routing.module';
|
import { MiningRoutingModule } from './mining-routing.module';
|
||||||
|
import { SharedModule } from '../shared/shared.module';
|
||||||
|
import { LoadComponent } from '../load/load.component';
|
||||||
|
import { MiningComponent } from './mining.component';
|
||||||
|
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
declarations: [],
|
declarations: [MiningComponent],
|
||||||
imports: [
|
imports: [
|
||||||
CommonModule,
|
CommonModule, SharedModule,MiningRoutingModule, LoadComponent
|
||||||
MiningRoutingModule
|
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
export class MiningModule { }
|
export class MiningModule { }
|
||||||
|
|
|
@ -260,13 +260,48 @@
|
||||||
<div class="row g-3">
|
<div class="row g-3">
|
||||||
<h4 class="mb-3">Synchronization</h4>
|
<h4 class="mb-3">Synchronization</h4>
|
||||||
|
|
||||||
<div class="form-check form-switch col-md-12">
|
<div class="form-check form-switch col-md-6">
|
||||||
<label for="sync-enabled" class="form-check-label">Enabled</label>
|
<label for="sync-enabled" class="form-check-label">Enabled</label>
|
||||||
<input class="form-control form-check-input" type="checkbox" role="switch" id="sync-enabled" checked>
|
<input class="form-control form-check-input" type="checkbox" role="switch" id="sync-enabled" checked>
|
||||||
<br>
|
<br>
|
||||||
<small class="text-body-secondary">Synchronize the blockchain with other peers</small>
|
<small class="text-body-secondary">Synchronize the blockchain with other peers</small>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="form-check form-switch col-md-6">
|
||||||
|
<label for="prune-blockchain" class="form-check-label">Prune Blockchain</label>
|
||||||
|
<input class="form-control form-check-input" type="checkbox" role="switch" id="prune-blockchain">
|
||||||
|
<br>
|
||||||
|
<small class="text-body-secondary">Reduce blockchain disk usage</small>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-check form-switch col-md-6">
|
||||||
|
<label for="sync-pruned-blocks" class="form-check-label">Sync pruned blocks</label>
|
||||||
|
<input class="form-control form-check-input" type="checkbox" role="switch" id="sync-pruned-blocks">
|
||||||
|
<br>
|
||||||
|
<small class="text-body-secondary">Allow syncing from nodes with only pruned blocks</small>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-check form-switch col-md-6">
|
||||||
|
<label for="fast-block-sync" class="form-check-label">Fast block sync</label>
|
||||||
|
<input class="form-control form-check-input" type="checkbox" role="switch" id="fast-block-sync">
|
||||||
|
<br>
|
||||||
|
<small class="text-body-secondary">Sync up most of the way by using embedded, known block hashes</small>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-check form-switch col-md-6">
|
||||||
|
<label for="relay-fluffly-blocks" class="form-check-label">Relay fluffy blocks</label>
|
||||||
|
<input class="form-control form-check-input" type="checkbox" role="switch" id="relay-fluffly-blocks" checked>
|
||||||
|
<br>
|
||||||
|
<small class="text-body-secondary">Relay blocks as fluffy blocks</small>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-check form-switch col-md-6">
|
||||||
|
<label for="keep-alt-blocks" class="form-check-label">Keep alternative blocks</label>
|
||||||
|
<input class="form-control form-check-input" type="checkbox" role="switch" id="keep-alt-blocks">
|
||||||
|
<br>
|
||||||
|
<small class="text-body-secondary">Keep alternative blocks on restart</small>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
<label for="block-sync-size" class="form-label">Block sync size</label>
|
<label for="block-sync-size" class="form-label">Block sync size</label>
|
||||||
<input type="number" class="form-control" id="block-sync-size" placeholder="" value="0">
|
<input type="number" class="form-control" id="block-sync-size" placeholder="" value="0">
|
||||||
|
@ -282,34 +317,6 @@
|
||||||
<input type="text" class="form-control" id="db-sync-mode" placeholder="fast:async:250000000bytes">
|
<input type="text" class="form-control" id="db-sync-mode" placeholder="fast:async:250000000bytes">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<br>
|
|
||||||
<br>
|
|
||||||
|
|
||||||
<div class="form-check">
|
|
||||||
<input type="checkbox" class="form-check-input" id="same-address">
|
|
||||||
<label class="form-check-label" for="same-address">Prune blockchain</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-check">
|
|
||||||
<input type="checkbox" class="form-check-input" id="save-info">
|
|
||||||
<label class="form-check-label" for="save-info">Sync pruned blocks</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-check">
|
|
||||||
<input type="checkbox" class="form-check-input" id="fast-block-sync">
|
|
||||||
<label class="form-check-label" for="fast-block-sync">Fast block sync</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-check">
|
|
||||||
<input type="checkbox" class="form-check-input" id="relay-fluffy-blocks" checked>
|
|
||||||
<label class="form-check-label" for="fast-block-sync">Relay fluffy blocks</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-check">
|
|
||||||
<input type="checkbox" class="form-check-input" id="keep-alt-blocks">
|
|
||||||
<label class="form-check-label" for="keep-alt-block">Keep alternative blocks on restart</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<hr class="my-4">
|
<hr class="my-4">
|
||||||
|
|
||||||
<h4 class="mb-3">Network type</h4>
|
<h4 class="mb-3">Network type</h4>
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
export { RPCRequest } from "./request/RPCRequest";
|
||||||
export { JsonRPCRequest } from "./request/JsonRPCRequest";
|
export { JsonRPCRequest } from "./request/JsonRPCRequest";
|
||||||
export { GetBlockCountRequest } from "./request/GetBlockCountRequest";
|
export { GetBlockCountRequest } from "./request/GetBlockCountRequest";
|
||||||
export { GetBlockHashRequest } from "./request/GetBlockHashRequest";
|
export { GetBlockHashRequest } from "./request/GetBlockHashRequest";
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
export abstract class JsonRPCRequest {
|
import { RPCRequest } from "./RPCRequest";
|
||||||
|
|
||||||
|
export abstract class JsonRPCRequest extends RPCRequest {
|
||||||
public readonly version: string = "2.0";
|
public readonly version: string = "2.0";
|
||||||
public readonly id: string = "0";
|
public readonly id: string = "0";
|
||||||
public abstract readonly method: string;
|
|
||||||
public abstract readonly restricted: boolean;
|
|
||||||
|
|
||||||
public toDictionary(): { [key: string]: any } {
|
public toDictionary(): { [key: string]: any } {
|
||||||
return {
|
return {
|
||||||
|
|
5
src/common/request/RPCRequest.ts
Normal file
5
src/common/request/RPCRequest.ts
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
export abstract class RPCRequest {
|
||||||
|
public abstract readonly method: string;
|
||||||
|
public abstract readonly restricted: boolean;
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in a new issue