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.
wow-lite-wallet/src/renderer/components/Landing/LandingPage.vue

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>