add multi-chain supports
This commit is contained in:
parent
b129a3a6a5
commit
044064dcc6
@ -51,7 +51,33 @@
|
||||
<h6 class="mb-0 text-uppercase">
|
||||
{{ selected_chain.chain_name }}
|
||||
</h6>
|
||||
<small v-b-tooltip.hover.bottom="'Data Provider'">{{ selected_chain.api }} ({{ selected_chain.sdk_version || '-' }})</small>
|
||||
<small id="data-provider">
|
||||
{{ currentApi }} ({{ selected_chain.sdk_version || '-' }})
|
||||
<b-dropdown
|
||||
v-if="apiOptions.length > 1"
|
||||
class="ml-0"
|
||||
variant="flat-primary"
|
||||
no-caret
|
||||
toggle-class="p-0"
|
||||
right
|
||||
sm
|
||||
>
|
||||
<template #button-content>
|
||||
<feather-icon
|
||||
icon="RepeatIcon"
|
||||
size="12"
|
||||
class="cursor-pointer"
|
||||
/>
|
||||
</template>
|
||||
<b-dropdown-item
|
||||
v-for="(item, i) in apiOptions"
|
||||
:key="item"
|
||||
@click="change(i)"
|
||||
>
|
||||
{{ item }}
|
||||
</b-dropdown-item>
|
||||
</b-dropdown>
|
||||
</small>
|
||||
</b-media-body>
|
||||
</b-media>
|
||||
</div>
|
||||
@ -171,9 +197,12 @@ export default {
|
||||
},
|
||||
},
|
||||
data() {
|
||||
const conf = store.state.chains.selected
|
||||
const s = localStorage.getItem(`${conf.chain_name}-api-index`)
|
||||
return {
|
||||
variant: 'success',
|
||||
tips: 'Synced',
|
||||
index: s || 0,
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
@ -188,6 +217,16 @@ export default {
|
||||
chainVariant() {
|
||||
return this.variant
|
||||
},
|
||||
currentApi() {
|
||||
return this.apiOptions[Number(this.index)]
|
||||
},
|
||||
apiOptions() {
|
||||
const conf = store.state.chains.selected
|
||||
if (Array.isArray(conf.api)) {
|
||||
return conf.api
|
||||
}
|
||||
return [conf.api]
|
||||
},
|
||||
},
|
||||
mounted() {
|
||||
const accounts = Object.keys(getLocalAccounts() || {})
|
||||
@ -196,6 +235,11 @@ export default {
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
change(v) {
|
||||
this.index = v
|
||||
const conf = store.state.chains.selected
|
||||
localStorage.setItem(`${conf.chain_name}-api-index`, v)
|
||||
},
|
||||
block() {
|
||||
store.commit('setHeight', 0)
|
||||
this.$http.getLatestBlock().then(block => {
|
||||
|
@ -249,10 +249,15 @@ export default class ChainFetch {
|
||||
this.getSelectedConfig()
|
||||
}
|
||||
host = (config ? config.api : this.config.api)
|
||||
const ret = await fetch((Array.isArray(host) ? host[0] : host) + url).then(response => response.json())
|
||||
const ret = await fetch((Array.isArray(host) ? host[this.getApiIndex(config)] : host) + url).then(response => response.json())
|
||||
return ret
|
||||
}
|
||||
|
||||
getApiIndex(config = null) {
|
||||
const conf = config || this.config
|
||||
return localStorage.getItem(`${conf.chain_name}-api-index`) || 0
|
||||
}
|
||||
|
||||
async getUrl(url) {
|
||||
this.getSelectedConfig()
|
||||
return fetch(url).then(res => res.json())
|
||||
@ -404,9 +409,10 @@ export default class ChainFetch {
|
||||
if (!config) {
|
||||
this.getSelectedConfig()
|
||||
}
|
||||
const host = (config ? config.api : this.config.api)
|
||||
const conf = config || this.config
|
||||
const index = localStorage.getItem(`${conf.chain_name}-api-index`) || 0
|
||||
// Default options are marked with *
|
||||
const response = await fetch((Array.isArray(host) ? host[0] : host) + url, {
|
||||
const response = await fetch((Array.isArray(conf.api) ? conf.api[Number(index)] : conf.api) + url, {
|
||||
method: 'POST', // *GET, POST, PUT, DELETE, etc.
|
||||
// mode: 'cors', // no-cors, *cors, same-origin
|
||||
// credentials: 'same-origin', // redirect: 'follow', // manual, *follow, error
|
||||
|
@ -92,9 +92,36 @@ export function setUserCurrency(currency) {
|
||||
}
|
||||
|
||||
export function chartColors() {
|
||||
const colors = ['#6610f2', '#20c997', '#000000', '#FF0000',
|
||||
'#800000', '#FFFF00', '#808000', '#00FF00', '#008000', '#00FFFF',
|
||||
'#008080', '#0000FF', '#000080', '#FF00FF', '#800080']
|
||||
const colors = [
|
||||
'#8A2BE2', '#9ACD32', '#000080', '#008080', '#DC143C',
|
||||
'#7FFFD4', '#B8860B', '#EEE8AA', '#FFFAFA', '#FDF5E6',
|
||||
'#C0C0C0', '#E6E6FA', '#FFFAF0', '#2E8B57', '#DCDCDC',
|
||||
'#FF1493', '#4682B4', '#191970', '#FF8C00', '#FFFFE0',
|
||||
'#696969', '#FFFACD', '#DEB887', '#4169E1', '#9932CC',
|
||||
'#B0C4DE', '#556B2F', '#FFE4E1', '#F5FFFA', '#8FBC8F',
|
||||
'#B22222', '#90EE90', '#FFFF00', '#4B0082', '#DB7093',
|
||||
'#F8F8FF', '#006400', '#6610f2', '#FFA500', '#7FFF00',
|
||||
'#87CEFA', '#5F9EA0', '#483D8B', '#CD5C5C', '#ADFF2F',
|
||||
'#2F4F4F', '#00FF7F', '#FFF5EE', '#F4A460', '#808000',
|
||||
'#000000', '#00FA9A', '#000000', '#EE82EE', '#F5DEB3',
|
||||
'#0000FF', '#BA55D3', '#FFF0F5', '#F5F5DC', '#0000CD',
|
||||
'#FFD700', '#708090', '#6B8E23', '#800000', '#7B68EE',
|
||||
'#FFA07A', '#800080', '#B0E0E6', '#00FFFF', '#00BFFF',
|
||||
'#7CFC00', '#778899', '#FF7F50', '#E0FFFF', '#6495ED',
|
||||
'#008B8B', '#DDA0DD', '#CD853F', '#FFFFF0', '#98FB98',
|
||||
'#9400D3', '#D2691E', '#FF0000', '#008000', '#00008B',
|
||||
'#C71585', '#FFB6C1', '#8B4513', '#20c997', '#FAEBD7',
|
||||
'#E9967A', '#FFEFD5', '#FFE4C4', '#D8BFD8', '#A52A2A',
|
||||
'#8B0000', '#32CD32', '#BDB76B', '#FF0000', '#DAA520',
|
||||
'#800000', '#9370DB', '#F08080', '#FAF0E6', '#FF6347',
|
||||
'#FF4500', '#FFFF00', '#808080', '#00CED1', '#FFC0CB',
|
||||
'#FF00FF', '#F0FFFF', '#A9A9A9', '#F0E68C', '#1E90FF',
|
||||
'#FFDAB9', '#228B22', '#F0FFF0', '#66CDAA', '#ADD8E6',
|
||||
'#DA70D6', '#A0522D', '#FFE4B5', '#48D1CC', '#D2B48C',
|
||||
'#FFEBCD', '#8B008B', '#3CB371', '#87CEEB', '#6A5ACD',
|
||||
'#FFDEAD', '#FF69B4', '#BC8F8F', '#D3D3D3', '#00FF00',
|
||||
'#FAFAD2', '#AFEEEE', '#40E0D0', '#FFF8DC', '#20B2AA',
|
||||
'#00FFFF', '#FA8072', '#F0F8FF']
|
||||
return Object.values($themeColors).concat(colors)
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user