assembly/pages/index.vue
2021-12-03 16:45:02 +08:00

158 lines
4.1 KiB
Vue

<template>
<div>
<h1 class="font-semibold text-2xl text-center">Assembly Apps</h1>
<div class="mt-10 grid w-full grid-cols-1 gap-4 sm:grid-cols-3 xl:gap-6">
<nuxt-link
v-for="app in apps"
:key="app.id"
:to="app.url"
class="relative flex flex-col items-center px-4 py-12 text-center rounded-[6px] cursor-pointer bg-white border border-transparent hover:border-[#1874FF] shadow"
>
<div
style="background: radial-gradient(42.15% 42.15% at 48.94% 48.94%, #D6DAE0 75.67%, #F0F3F9 100%), #C4C4C4;"
class="w-20 h-20 rounded-full flex items-center justify-center border border-[#CCDCF3]"
>
<div
class="w-16 h-16 rounded-full flex items-center justify-center bg-[#1874FF]"
>
<component :is="app.icon" class="w-10 h-10 text-white" />
</div>
</div>
<h2 class="mt-4 font-semibold text-19">{{ app.name }}</h2>
<p class="mt-2 text-14 font-regular text-grey-dark opacity-90"
v-html="app.description">
</p>
</nuxt-link>
</div>
</div>
</template>
<script lang="ts">
import { computed, defineComponent } from "@nuxtjs/composition-api";
import { useNetwork } from "~/composables/useNetwork";
import AaveIcon from "~/assets/icons/aave.svg?inline";
import CompoundIcon from "~/assets/icons/compound.svg?inline";
import MakerIcon from "~/assets/icons/makerdao.svg?inline";
import OneInchIcon from "~/assets/icons/1inch.svg?inline";
import LiquityIcon from "~/assets/icons/liquity.svg?inline";
import BprotocolIcon from "~/assets/icons/b-protocol.svg?inline";
import ReflexerIcon from "~/assets/icons/reflexer.svg?inline";
import YearnIcon from "~/assets/icons/yearn.svg?inline";
import UniverseIcon from "~/assets/icons/universe.svg?inline";
const appsPerNetwork = {
mainnet: [
{
id: "aave-v2",
icon: AaveIcon,
name: "Aave v2",
url: "/aave-v2",
description: "Money Market"
},
{
id: "compound",
icon: CompoundIcon,
name: "Compound",
url: "/mainnet/compound",
description: "Money Market"
},
{
id: "maker",
icon: MakerIcon,
name: "MakerDAO",
url: "/mainnet/maker",
description: "Collateralized DAI Debt"
},
{
id: "1inch",
icon: OneInchIcon,
name: "1inch",
url: "/1inch",
description: "DEX Aggregator"
},
{
id: "liquity",
icon: LiquityIcon,
name: "Liquity",
url: "/mainnet/liquity",
description: "Collateralized LUSD Debt"
},
{
id: "bprotocol",
icon: BprotocolIcon,
name: "B.Protocol v2",
url: "/mainnet/bprotocol",
description: "Automated Rebalancing <br/>for Liquity Stability Pool"
},
{
id: "reflexer",
icon: ReflexerIcon,
name: "Reflexer Finance",
url: "/mainnet/reflexer",
description: "Collateralized RAI Debt"
},
{
id: "yearn-v2",
icon: YearnIcon,
name: "Yearn",
url: "/mainnet/yearn-v2",
description: "Automated Yield Strategies"
},
{
id: "universe",
icon: UniverseIcon,
name: "Universe",
url: "/mainnet/universe",
description: "Maximizing your Uniswap V3 Return"
},
],
polygon: [
{
id: "aave-v2",
icon: AaveIcon,
name: "Aave v2",
url: "/aave-v2",
description: "Lend and borrow straight from your Gnosis Safe"
},
{
id: "1inch",
icon: OneInchIcon,
name: "1inch",
url: "/1inch",
description: "DEX Aggregator"
}
],
arbitrum: [
{
id: "1inch",
icon: OneInchIcon,
name: "1inch",
url: "/1inch",
description: "DEX Aggregator"
}
],
avalanche: [
{
id: "aave-v2",
icon: AaveIcon,
name: "Aave v2",
url: "/aave-v2",
description: "Lend and borrow straight from your Gnosis Safe"
}
]
};
export default defineComponent({
setup() {
const { activeNetworkId } = useNetwork();
const apps = computed(() => appsPerNetwork[activeNetworkId.value]);
return {
apps
};
}
});
</script>