add i18n for index, improve chain profile

This commit is contained in:
liangping 2023-02-14 09:58:28 +08:00
parent f2d088a42b
commit e6f32d6716
8 changed files with 33 additions and 11 deletions

View File

@ -47,7 +47,7 @@ const logoPath = computed(() => {
activator="parent"
location="top"
>
Add to favorite
{{ $t('index.add_to_favorite') }}
</VTooltip>
</VListItemAction>
</template>

View File

@ -34,7 +34,7 @@ const chainStore = useBlockchain()
<!-- 👉 Rest -->
<VListSubheader v-if="chainStore.current.apis?.rest" title="Rest Endpoint" />
<VListItem v-for="i in chainStore.current.apis?.rest" link @click="chainStore.setRestEndpoint(i.address)">
<VListItemTitle>{{ i.provider }} <VIcon v-if="chainStore.availableEndpoint && i.address === chainStore.availableEndpoint" icon="mdi-check" color="primary" /></VListItemTitle>
<VListItemTitle>{{ i.provider }} <VIcon v-if="chainStore.availableEndpoint && i.address === chainStore.availableEndpoint" icon="mdi-check" color="success" /></VListItemTitle>
<VListItemSubtitle>{{ i.address }}</VListItemSubtitle>
</VListItem>

View File

@ -13,6 +13,7 @@ import { VerticalNavLayout } from '@layouts'
import NavBarI18n from './NavBarI18n.vue'
import NavSearchBar from './NavSearchBar.vue'
import NavBarNotifications from './NavBarNotifications.vue'
import TheCustomizer from '@/plugins/vuetify/@core/components/TheCustomizer.vue'
const { appRouteTransition, isLessThanOverlayNavBreakpoint, isVerticalNavCollapsed } = useThemeConfig()
const { width: windowWidth } = useWindowSize()

View File

@ -20,7 +20,7 @@ const chains = computed(()=> {
</script>
<template>
<div class="d-flex flex-column justify-center">
<div class="d-flex justify-center align-self-center p-1 b1">
<div class="d-flex justify-center align-center align-self-center p-1 b1">
<VImg src="/logo.svg" width="85" height="85"/>
<h1 class="text-primary text-h3 font-weight-bold d-none d-md-block ml-1">
Ping Dashboard<VChip>Beta</VChip>
@ -28,14 +28,14 @@ const chains = computed(()=> {
</div>
<div class="d-flex flex-column align-center">
<p class="mb-1">
Ping Dashboard is not just an explorer but also a wallet and more ... 🛠
{{ $t('index.slogan') }}
</p>
<h2 class="mb-9">
Cosmos Ecosystem Blockchains 🚀
</h2>
</div>
<VProgressLinear v-if="dashboard.status !== LoadingStatus.Loaded " indeterminate color="primary darken-2"/>
<VTextField v-model="keywords" variant="underlined" placeholder="Search chain name" style="max-width: 300px;" app>
<VTextField v-model="keywords" variant="underlined" :placeholder="$t('index.search_placeholder')" style="max-width: 300px;" app>
<template #append-inner>
{{ chains.length }}/{{ dashboard.length }}
</template>

View File

@ -3,6 +3,11 @@
"chain": "面板首页",
"chain-test": "测试功能",
},
"index": {
"slogan": "Ping Dashboard 是一个区块链浏览器,也是一个网页钱包,还有更多 ... 🛠",
"search_placeholder": "搜索区块链",
"add_to_favorite": "加入收藏夹"
},
"Ecosystem": "生态系统",
"All Blockchains": "全部区块链",
"Favorite": "收藏夹"

View File

@ -3,7 +3,13 @@
"chain": "Dashboard",
"chain-test": "test",
},
"index": {
"slogan": "Ping Dashboard is not just an explorer but also a wallet and more ... 🛠",
"search_placeholder": "Search Chain",
"add_to_favorite": "Add to favorite"
},
"Ecosystem": "Ecosystem",
"All Blockchains": "All Blockchain222",
"Favorite": "Favorite"
}

View File

@ -1,7 +1,7 @@
import { ref, computed } from "vue";
import { defineStore } from "pinia";
import { getLogo, useDashboard } from "./useDashboard";
import { useTheme } from 'vuetify'
export const useBlockchain = defineStore("blockchain", () => {
const dbstore = useDashboard()
@ -18,12 +18,22 @@ export const useBlockchain = defineStore("blockchain", () => {
const name = computed(() => {
return current.value.chain_name
})
const primaryColor = computed(() => {
const colors = ['#fff', '#fea', '#123', '#68f', '#aca', 'bbe', '#666CFF']
const color = colors[Math.floor(Math.random() * colors.length)]
const vuetifyTheme = useTheme()
const currentThemeName = vuetifyTheme.name.value
vuetifyTheme.themes.value[currentThemeName].colors.primary = color
return color
})
const availableEndpoint = computed(() => {
const all = current.value?.apis?.rest
if(all) {
if(!rest.value || all.findIndex(x => x.address === rest.value) < 0) {
const rn = Math.random()
rest.value = all[Math.floor(rn * all.length)].address
const endpoint = all[Math.floor(rn * all.length)]
rest.value = endpoint?.address || ''
}
}
@ -38,7 +48,7 @@ export const useBlockchain = defineStore("blockchain", () => {
// states
availableEndpoint,
// getters
name, current, logo,
name, current, logo, primaryColor,
// actions
setRestEndpoint
};

View File

@ -147,7 +147,7 @@ export const useDashboard = defineStore("dashboard", () => {
title: 'Favorite',
children: favNavItems,
badgeContent: favorite.value.length,
badgeClass: 'bg-error',
badgeClass: 'bg-primary',
i18n: true,
icon: { icon: 'mdi-star', size: '22'}
},
@ -155,7 +155,7 @@ export const useDashboard = defineStore("dashboard", () => {
title: 'All Blockchains',
to: { path : '/'},
badgeContent: length.value,
badgeClass: 'bg-error',
badgeClass: 'bg-primary',
i18n: true,
icon: { icon: 'mdi-grid', size: '22'}
}