Fix button and roundings

This commit is contained in:
AlphaX-Projects 2022-08-29 20:08:50 +02:00
parent 39b461d480
commit cb252c3fa7
5 changed files with 240 additions and 308 deletions

View File

@ -36,7 +36,7 @@
"electron-log": "4.4.8" "electron-log": "4.4.8"
}, },
"devDependencies": { "devDependencies": {
"electron": "19.0.14", "electron": "20.1.0",
"electron-builder": "23.3.3", "electron-builder": "23.3.3",
"electron-notarize": "1.2.1", "electron-notarize": "1.2.1",
"electron-packager": "16.0.0", "electron-packager": "16.0.0",

View File

@ -9,6 +9,7 @@ import '@vaadin/icons';
import '../functional-components/side-menu.js'; import '../functional-components/side-menu.js';
import '../functional-components/side-menu-item.js'; import '../functional-components/side-menu-item.js';
import './start-minting.js'
class SidenavMenu extends connect(store)(LitElement) { class SidenavMenu extends connect(store)(LitElement) {
static get properties() { static get properties() {
@ -44,13 +45,6 @@ class SidenavMenu extends connect(store)(LitElement) {
border-top: 1px solid var(--border); border-top: 1px solid var(--border);
outline: none; outline: none;
} }
.start-minting-wrapper {
position: absolute;
bottom: 130px;
left: 50%;
transform: translateX(calc(-50% - 10px));
}
`, `,
]; ];
} }
@ -59,9 +53,7 @@ class SidenavMenu extends connect(store)(LitElement) {
super(); super();
this.urls = []; this.urls = [];
this.nodeType = ''; this.nodeType = '';
this.theme = localStorage.getItem('qortalTheme') this.theme = localStorage.getItem('qortalTheme') ? localStorage.getItem('qortalTheme') : 'light';
? localStorage.getItem('qortalTheme')
: 'light';
this.addressInfo = {}; this.addressInfo = {};
} }
@ -225,15 +217,15 @@ class SidenavMenu extends connect(store)(LitElement) {
</side-menu-item> </side-menu-item>
${this.renderNodeManagement()} ${this.renderNodeManagement()}
</side-menu-item> </side-menu-item>
<div style="margin-top: 20px;">
<start-minting></start-minting>
</div>
`; `;
} }
} }
renderNodeManagement() { renderNodeManagement() {
const checkNodeManagement = const checkNodeManagement = store.getState().app.nodeConfig.knownNodes[store.getState().app.nodeConfig.node];
store.getState().app.nodeConfig.knownNodes[
store.getState().app.nodeConfig.node
];
if ((checkNodeManagement.enableManagement = true)) { if ((checkNodeManagement.enableManagement = true)) {
return html` return html`
<side-menu-item <side-menu-item

View File

@ -7,22 +7,19 @@ import { asyncReplace } from 'lit/directives/async-replace.js';
import '../functional-components/my-button.js'; import '../functional-components/my-button.js';
import { routes } from '../plugins/routes.js'; import { routes } from '../plugins/routes.js';
import "@material/mwc-button" import "@material/mwc-button"
import '@material/mwc-dialog' import '@material/mwc-dialog'
async function* countDown(count, callback) { async function* countDown(count, callback) {
while (count > 0) { while (count > 0) {
yield count--; yield count--;
await new Promise((r) => setTimeout(r, 1000)); await new Promise((r) => setTimeout(r, 1000));
if (count === 0) { if (count === 0) {
callback() callback()
} }
} }
} }
class StartMinting extends connect(store)(LitElement) { class StartMinting extends connect(store)(LitElement) {
static get properties() { static get properties() {
return { return {
@ -195,27 +192,23 @@ class StartMinting extends connect(store)(LitElement) {
renderErrorMsg1() { renderErrorMsg1() {
return html`${translate("startminting.smchange1")}` return html`${translate("startminting.smchange1")}`
} }
renderErrorMsg2() { renderErrorMsg2() {
return html`${translate("startminting.smchange2")}` return html`${translate("startminting.smchange2")}`
} }
renderErrorMsg3() { renderErrorMsg3() {
return html`${translate("startminting.smchange3")}` return html`${translate("startminting.smchange3")}`
} }
renderErrorMsg4() { renderErrorMsg4() {
return html`${translate("startminting.smchange4")}` return html`${translate("startminting.smchange4")}`
} }
async getMintingAcccounts() { async getMintingAcccounts() {
const myNode = const myNode = store.getState().app.nodeConfig.knownNodes[store.getState().app.nodeConfig.node];
store.getState().app.nodeConfig.knownNodes[ const nodeUrl = myNode.protocol + '://' + myNode.domain + ':' + myNode.port;
store.getState().app.nodeConfig.node
];
const nodeUrl =
myNode.protocol + '://' + myNode.domain + ':' + myNode.port;
const url = `${nodeUrl}/admin/mintingaccounts`; const url = `${nodeUrl}/admin/mintingaccounts`;
try { try {
const res = await fetch(url); const res = await fetch(url);
@ -225,28 +218,19 @@ async getMintingAcccounts() {
} catch (error) { } catch (error) {
this.errorMsg = this.renderErrorMsg1(); this.errorMsg = this.renderErrorMsg1();
} }
} }
async changeStatus(value){ async changeStatus(value){
const myNode = const myNode = store.getState().app.nodeConfig.knownNodes[store.getState().app.nodeConfig.node];
store.getState().app.nodeConfig.knownNodes[ const nodeUrl = myNode.protocol + '://' + myNode.domain + ':' + myNode.port;
store.getState().app.nodeConfig.node
];
const nodeUrl =
myNode.protocol + '://' + myNode.domain + ':' + myNode.port;
this.status = value this.status = value
const publicAddress = const publicAddress = window.parent.reduxStore.getState().app?.selectedAddress ?.base58PublicKey;
window.parent.reduxStore.getState().app?.selectedAddress
?.base58PublicKey;
// Check to see if a sponsorship key on a newly-level 1 minter exists. If it does, remove it. // Check to see if a sponsorship key on a newly-level 1 minter exists. If it does, remove it.
const findMintingAccountFromOtherUser = this.mintingAccountData.find( const findMintingAccountFromOtherUser = this.mintingAccountData.find((ma) => !ma.publicKey.includes(publicAddress));
(ma) => !ma.publicKey.includes(publicAddress)
);
const removeMintingAccount = async (publicKey) => { const removeMintingAccount = async (publicKey) => {
const url = `${nodeUrl}/admin/mintingaccounts?apiKey=${myNode.apiKey}`; const url = `${nodeUrl}/admin/mintingaccounts?apiKey=${myNode.apiKey}`;
return await fetch(url, { return await fetch(url, {
method: 'DELETE', method: 'DELETE',
body: publicKey, body: publicKey,
@ -255,7 +239,6 @@ async changeStatus(value){
const addMintingAccount = async (sponsorshipKeyValue) => { const addMintingAccount = async (sponsorshipKeyValue) => {
const url = `${nodeUrl}/admin/mintingaccounts?apiKey=${myNode.apiKey}`; const url = `${nodeUrl}/admin/mintingaccounts?apiKey=${myNode.apiKey}`;
return await fetch(url, { return await fetch(url, {
method: 'POST', method: 'POST',
body: sponsorshipKeyValue, body: sponsorshipKeyValue,
@ -287,8 +270,7 @@ async changeStatus(value){
this.errorMsg = this.renderErrorMsg3(); this.errorMsg = this.renderErrorMsg3();
return; return;
} }
}
}
async confirmRelationship(){ async confirmRelationship(){
const myNode = const myNode =
@ -337,38 +319,17 @@ async confirmRelationship(){
interval = setInterval(getAnswer, 5000); interval = setInterval(getAnswer, 5000);
} }
renderStartMintingButton() { renderStartMintingButton() {
const myNode = const myNode = store.getState().app.nodeConfig.knownNodes[store.getState().app.nodeConfig.node];
store.getState().app.nodeConfig.knownNodes[ const nodeUrl = myNode.protocol + '://' + myNode.domain + ':' + myNode.port;
store.getState().app.nodeConfig.node
];
const nodeUrl =
myNode.protocol + '://' + myNode.domain + ':' + myNode.port;
const mintingAccountData = this.mintingAccountData; const mintingAccountData = this.mintingAccountData;
const addressInfo = window.parent.reduxStore.getState().app.accountInfo.addressInfo const addressInfo = window.parent.reduxStore.getState().app.accountInfo.addressInfo
const address = window.parent.reduxStore.getState().app?.selectedAddress?.address;
const nonce = window.parent.reduxStore.getState().app?.selectedAddress?.nonce;
const publicAddress = window.parent.reduxStore.getState().app?.selectedAddress ?.base58PublicKey;
const findMintingAccount = mintingAccountData.find((ma) => ma.mintingAccount === address);
const isMinterButKeyMintingKeyNotAssigned = addressInfo?.error !== 124 && addressInfo?.level >= 1 && !findMintingAccount;
const address =
window.parent.reduxStore.getState().app?.selectedAddress?.address;
const nonce =
window.parent.reduxStore.getState().app?.selectedAddress?.nonce;
const publicAddress =
window.parent.reduxStore.getState().app?.selectedAddress
?.base58PublicKey;
const findMintingAccount = mintingAccountData.find((ma) =>
ma.mintingAccount === address
);
const isMinterButKeyMintingKeyNotAssigned =
addressInfo?.error !== 124 &&
addressInfo?.level >= 1 &&
!findMintingAccount;
const makeTransactionRequest = async (lastRef) => { const makeTransactionRequest = async (lastRef) => {
let mylastRef = lastRef; let mylastRef = lastRef;
let rewarddialog1 = get('transactions.rewarddialog1'); let rewarddialog1 = get('transactions.rewarddialog1');
@ -423,24 +384,18 @@ renderStartMintingButton() {
return myTransaction?.extraData?.rewardSharePrivateKey return myTransaction?.extraData?.rewardSharePrivateKey
}; };
const getLastRef = async () => { const getLastRef = async () => {
const url = `${nodeUrl}/addresses/lastreference/${address}`; const url = `${nodeUrl}/addresses/lastreference/${address}`;
const res = await fetch(url); const res = await fetch(url);
const data = await res.text(); const data = await res.text();
return data; return data;
}; };
const startMinting = async () => { const startMinting = async () => {
this.openDialogRewardShare = true this.openDialogRewardShare = true
this.errorMsg = ''; this.errorMsg = '';
try { try {
this.privateRewardShareKey = await createSponsorshipKey(); this.privateRewardShareKey = await createSponsorshipKey();
this.confirmRelationship(publicAddress) this.confirmRelationship(publicAddress)
} catch (error) { } catch (error) {
@ -448,18 +403,12 @@ renderStartMintingButton() {
this.errorMsg = error?.data?.message || this.renderErrorMsg4(); this.errorMsg = error?.data?.message || this.renderErrorMsg4();
return; return;
} }
}; };
return html` return html`
${isMinterButKeyMintingKeyNotAssigned ${isMinterButKeyMintingKeyNotAssigned ? html`
? html`
<div class="start-minting-wrapper"> <div class="start-minting-wrapper">
<my-button <my-button label="${translate('becomeMinterPage.bchange18')}"
label="${translate(
'becomeMinterPage.bchange18'
)}"
?isLoading=${false} ?isLoading=${false}
.onClick=${async () => { .onClick=${async () => {
await startMinting(); await startMinting();
@ -469,21 +418,20 @@ renderStartMintingButton() {
}); });
} }
}} }}
></my-button> >
</my-button>
</div> </div>
<!-- Dialog for tracking the progress of starting minting --> <!-- Dialog for tracking the progress of starting minting -->
${this.openDialogRewardShare ? html` ${this.openDialogRewardShare ? html`
<div class="dialogCustom"> <div class="dialogCustom">
<div class="dialogCustomInner"> <div class="dialogCustomInner">
<div class="dialog-header" > <div class="dialog-header" >
<div class="row"> <div class="row">
<h1>In progress </h1> <div class=${`smallLoading marginLoader ${this.status > 3 && 'hide'}`}></div> <h1>In progress</h1>
<div class=${`smallLoading marginLoader ${this.status > 3 && 'hide'}`}></div>
</div> </div>
<hr /> <hr />
</div> </div>
<div class="dialog-container"> <div class="dialog-container">
@ -538,31 +486,26 @@ renderStartMintingButton() {
@click=${() => { @click=${() => {
this.openDialogRewardShare = false this.openDialogRewardShare = false
this.errorMsg = '' this.errorMsg = ''
}} }}
class="red" class="red"
> >
${translate("general.close")} ${translate("general.close")}
</mwc-button> </mwc-button>
` : '' } ` : '' }
</div> </div>
</div> </div>
<!-- </mwc-dialog> --> <!-- </mwc-dialog> -->
</div> </div>
` : ""} ` : ""}
` : ''}
`
: ''}
`; `;
} }
stateChanged(state) { stateChanged(state) {
this.addressInfo = state.app.accountInfo.addressInfo; this.addressInfo = state.app.accountInfo.addressInfo;
} }
} }
window.customElements.define('start-minting', StartMinting); window.customElements.define('start-minting', StartMinting);

View File

@ -6,8 +6,6 @@ import { translate, translateUnsafeHTML } from 'lit-translate'
import '@polymer/paper-toast' import '@polymer/paper-toast'
import '@material/mwc-icon-button' import '@material/mwc-icon-button'
import './start-minting.js'
class WalletProfile extends connect(store)(LitElement) { class WalletProfile extends connect(store)(LitElement) {
static get properties() { static get properties() {
return { return {
@ -90,7 +88,6 @@ class WalletProfile extends connect(store)(LitElement) {
<p id="blocksMinted">${translate("walletprofile.blocksminted")} - ${this.accountInfo.addressInfo.blocksMinted + this.accountInfo.addressInfo.blocksMintedAdjustment}</p> <p id="blocksMinted">${translate("walletprofile.blocksminted")} - ${this.accountInfo.addressInfo.blocksMinted + this.accountInfo.addressInfo.blocksMintedAdjustment}</p>
<p id="address">${this.wallet.addresses[0].address}</p> <p id="address">${this.wallet.addresses[0].address}</p>
</div> </div>
<start-minting></start-minting>
</div> </div>
<paper-toast id="toast" horizontal-align="right" vertical-align="top" vertical-offset="64"></paper-toast> <paper-toast id="toast" horizontal-align="right" vertical-align="top" vertical-offset="64"></paper-toast>
` `

View File

@ -36,7 +36,7 @@ export default class PaymentTransaction extends TransactionBase {
} }
set amount(amount) { set amount(amount) {
this._amount = amount * store.getState().config.coin.decimals this._amount = Math.round(amount * store.getState().config.coin.decimals)
this._amountBytes = this.constructor.utils.int64ToBytes(this._amount) this._amountBytes = this.constructor.utils.int64ToBytes(this._amount)
} }