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" activator="parent"
location="top" location="top"
> >
Add to favorite {{ $t('index.add_to_favorite') }}
</VTooltip> </VTooltip>
</VListItemAction> </VListItemAction>
</template> </template>

View File

@ -34,7 +34,7 @@ const chainStore = useBlockchain()
<!-- 👉 Rest --> <!-- 👉 Rest -->
<VListSubheader v-if="chainStore.current.apis?.rest" title="Rest Endpoint" /> <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)"> <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> <VListItemSubtitle>{{ i.address }}</VListItemSubtitle>
</VListItem> </VListItem>

View File

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

View File

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

View File

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

View File

@ -3,7 +3,13 @@
"chain": "Dashboard", "chain": "Dashboard",
"chain-test": "test", "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", "Ecosystem": "Ecosystem",
"All Blockchains": "All Blockchain222", "All Blockchains": "All Blockchain222",
"Favorite": "Favorite" "Favorite": "Favorite"
} }

View File

@ -1,7 +1,7 @@
import { ref, computed } from "vue"; import { ref, computed } from "vue";
import { defineStore } from "pinia"; import { defineStore } from "pinia";
import { getLogo, useDashboard } from "./useDashboard"; import { getLogo, useDashboard } from "./useDashboard";
import { useTheme } from 'vuetify'
export const useBlockchain = defineStore("blockchain", () => { export const useBlockchain = defineStore("blockchain", () => {
const dbstore = useDashboard() const dbstore = useDashboard()
@ -18,12 +18,22 @@ export const useBlockchain = defineStore("blockchain", () => {
const name = computed(() => { const name = computed(() => {
return current.value.chain_name 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 availableEndpoint = computed(() => {
const all = current.value?.apis?.rest const all = current.value?.apis?.rest
if(all) { if(all) {
if(!rest.value || all.findIndex(x => x.address === rest.value) < 0) { if(!rest.value || all.findIndex(x => x.address === rest.value) < 0) {
const rn = Math.random() 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 // states
availableEndpoint, availableEndpoint,
// getters // getters
name, current, logo, name, current, logo, primaryColor,
// actions // actions
setRestEndpoint setRestEndpoint
}; };

View File

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