forked from wownero/wow-lite-wallet
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
7.0 KiB
188 lines
7.0 KiB
<template>
|
|
<main class="landing">
|
|
<div class="row">
|
|
<div class="col-sm-7">
|
|
<img id="logo" src="~@/assets/wownero-light-intro.png" alt="electron-vue">
|
|
|
|
<button id="create_wallet_btn" v-on:click="createWallet" type="button" class="btn btn-success btn-sm">
|
|
<i class="fa fa-plus" id="create_wallet_icon" aria-hidden="true"></i>
|
|
Create wallet
|
|
</button>
|
|
|
|
<button id="create_wallet_btn" v-on:click="openWallet" type="button" class="btn btn-success btn-sm">
|
|
<i class="fa fa-plus" id="create_wallet_icon" aria-hidden="true"></i>
|
|
Open wallet
|
|
</button>
|
|
|
|
<button id="" v-on:click="settings" type="button" class="btn btn-success btn-sm">
|
|
<!-- fa fa-refresh fa-spin -->
|
|
<i class="fa fa-cog" aria-hidden="true"></i>
|
|
Settings
|
|
</button>
|
|
|
|
<button type="button" class="btn btn-success btn-sm">
|
|
Does nothing
|
|
</button>
|
|
</div>
|
|
|
|
<div class="col-sm-5">
|
|
<div class="card my-4" style="margin-top: 0 !important;">
|
|
<h5 class="card-header">Node</h5>
|
|
<div class="card-body node">
|
|
<div class="form-group node_select">
|
|
<select id="selectnode" class="form-control">
|
|
<option :selected="selected_node === node.address" v-bind:value="node.address" v-for="node in nodes">{{node.region}} - {{node.address}}</option>
|
|
</select>
|
|
<div class="node_status">
|
|
<small class="location"></small>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<wario-landing></wario-landing>
|
|
<transition name="fade">
|
|
<div class="refresh" v-if='wallet.state === 3'>
|
|
<div class="box">
|
|
<div class="text">
|
|
{{height_from}} / {{height_to}}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</transition>
|
|
</main>
|
|
</template>
|
|
|
|
<script>
|
|
import WalletExplorer from './components/WalletExplorer'
|
|
import WfsExplorer from './components/WfsExplorer'
|
|
import WarioLanding from './WarioLanding'
|
|
|
|
export default {
|
|
name: 'LandingPage',
|
|
components: {WalletExplorer, WfsExplorer, WarioLanding},
|
|
beforeRouteLeave(to, from, next) {
|
|
next();
|
|
},
|
|
methods: {
|
|
open(link) {
|
|
this.$electron.shell.openExternal(link)
|
|
},
|
|
settings(){
|
|
this.$router.push({name: 'settings'});
|
|
},
|
|
createWallet(){
|
|
// make sure any stale process is killed anyway ;/
|
|
ipcRenderer.send('rpc_kill_wallet');
|
|
|
|
this.$router.push({name: 'create-wallet-options'});
|
|
},
|
|
openWallet(){
|
|
const {dialog} = require('electron').remote;
|
|
|
|
dialog.showOpenDialog({
|
|
defaultPath: this.$store.state.wallet_dir,
|
|
properties: ['openFile'],
|
|
filters: {
|
|
name: 'All Files',
|
|
extensions: ['*.keys']
|
|
}
|
|
}, (files) => {
|
|
if (files !== undefined) {
|
|
this.$store.commit('addWalletPath', files[0]);
|
|
|
|
this.$store.commit('showPassword', {
|
|
'message': 'Enter wallet password'
|
|
});
|
|
|
|
setTimeout(() => {
|
|
jQuery('#password').focus();
|
|
}, 50);
|
|
}
|
|
});
|
|
},
|
|
openLastWallet(event){
|
|
const selectedWallet = this.cfg_wallets.find(i => i.name === event.currentTarget.text);
|
|
this.$store.commit('addWalletPath', selectedWallet.path);
|
|
this.$store.commit('showPassword', {
|
|
'message': 'Enter wallet password'
|
|
});
|
|
|
|
setTimeout(() => {
|
|
jQuery('#password').focus();
|
|
}, 50);
|
|
}
|
|
},
|
|
mounted() {
|
|
let select_node = jQuery('#selectnode');
|
|
const axios = require('axios');
|
|
axios.get('https://tradeogre.com/api/v1/ticker/btc-wow').then(response => {
|
|
this.$store.commit('addRate', response.data.ask);
|
|
});
|
|
|
|
axios.get('https://tradeogre.com/api/v1/ticker/btc-xmr').then(response => {
|
|
this.$store.commit('addRateXMR', response.data.ask);
|
|
});
|
|
|
|
axios.get(`https://funding.wownero.com/api/1/wowlite?version=0.1.4`).then(response => {
|
|
if(response.data.data === false) {
|
|
const {dialog} = require('electron').remote
|
|
const dialogOptions = {
|
|
type: 'error',
|
|
title: 'Outdated client',
|
|
buttons: ['OK'],
|
|
message: `You are running an old instance of wowlite and need to upgrade!\n\nVisit https://light.wownero.com for a shiny new version.`
|
|
}
|
|
dialog.showMessageBox(dialogOptions, i => {});
|
|
}
|
|
});
|
|
|
|
this.$electron.ipcRenderer.on('rpc_wallet_opening', (event) => {
|
|
console.log('opening');
|
|
this.$store.commit('showMessage', {
|
|
'title': 'Opening Wallet...',
|
|
'message': ''
|
|
});
|
|
});
|
|
|
|
select_node.on('change', (fuckme) => {
|
|
let address = fuckme.currentTarget.value;
|
|
let nodes = this.$store.getters.cfg.nodes;
|
|
let node = nodes.find(_node => _node.address === address)
|
|
|
|
ipcRenderer.send('rpc_cfg_set_node', node.address);
|
|
|
|
jQuery('.node_status .location').html(`Location: ${node.location}`);
|
|
});
|
|
},
|
|
computed: {
|
|
walletDir(){
|
|
return this.$store.state.wallet_dir;
|
|
},
|
|
height_from() {
|
|
return this.$store.getters.height_from;
|
|
},
|
|
height_to() {
|
|
return this.$store.getters.height_to;
|
|
},
|
|
wallet(){
|
|
return this.$store.state.wallet;
|
|
},
|
|
nodes(){
|
|
return this.$store.getters.cfg.nodes;
|
|
},
|
|
selected_node(){
|
|
return this.$store.getters.cfg.node;
|
|
},
|
|
cfg_wallets(){
|
|
return this.$store.getters.cfg.wallets;
|
|
},
|
|
cfg_wallet_names(){
|
|
return this.$store.getters.cfg.wallets.map(i => i.name);
|
|
}
|
|
}
|
|
}
|
|
</script>
|