Merge branch 'new-CounterFire' of http://git.kingsome.cn/huangjinming/CounterFireGames into new-CounterFire
This commit is contained in:
commit
873c6a77cd
@ -3,7 +3,7 @@
|
|||||||
<div class="card-top" v-if="nftData">
|
<div class="card-top" v-if="nftData">
|
||||||
<!-- @click="toDetail" -->
|
<!-- @click="toDetail" -->
|
||||||
<div class="card-img" @click="toDetail">
|
<div class="card-img" @click="toDetail">
|
||||||
<img :src="nftData.image" alt="图片">
|
<LazyLoadImg :src="nftData.image" :src-placeholder="placeholderImg" alt="图片"/>
|
||||||
</div>
|
</div>
|
||||||
<div class="card-name">
|
<div class="card-name">
|
||||||
<div>Cotnesford park</div>
|
<div>Cotnesford park</div>
|
||||||
@ -35,6 +35,8 @@ import SellDialog from "@/components/Dialogs/sellDialog.vue"
|
|||||||
import {PassportWallet} from "@/wallet/passPort.js"
|
import {PassportWallet} from "@/wallet/passPort.js"
|
||||||
import { useDetailStore } from "@/store/detail"
|
import { useDetailStore } from "@/store/detail"
|
||||||
import { apiGetPrice } from "@/utils/marketplace"
|
import { apiGetPrice } from "@/utils/marketplace"
|
||||||
|
import LazyLoadImg from "@/components/lazyloadimg"
|
||||||
|
import placeholderImg from '@/assets/img/marketplace/GenesisHeroes_NFT.png'
|
||||||
// import BuyDialog from "@/components/Dialogs/buyDialog.vue"
|
// import BuyDialog from "@/components/Dialogs/buyDialog.vue"
|
||||||
|
|
||||||
import {
|
import {
|
||||||
|
@ -45,8 +45,10 @@ export class BlockChain {
|
|||||||
|
|
||||||
async restoreWallet(walletType) {
|
async restoreWallet(walletType) {
|
||||||
this.wallet = new allProviders[walletType]();
|
this.wallet = new allProviders[walletType]();
|
||||||
const { provider } = await this.wallet.web3Provider();
|
const { provider, token } = await this.wallet.web3Provider();
|
||||||
this.provider = provider
|
this.provider = provider
|
||||||
|
this.token = token
|
||||||
|
this.store.$persist();
|
||||||
this.market.updateProvider(provider);
|
this.market.updateProvider(provider);
|
||||||
return provider;
|
return provider;
|
||||||
}
|
}
|
||||||
@ -56,11 +58,12 @@ export class BlockChain {
|
|||||||
if (ALL_PROVIDERS.length === 1) {
|
if (ALL_PROVIDERS.length === 1) {
|
||||||
const walletType = ALL_PROVIDERS[0].id
|
const walletType = ALL_PROVIDERS[0].id
|
||||||
this.wallet = new allProviders[walletType]();
|
this.wallet = new allProviders[walletType]();
|
||||||
const { provider, accounts } = await this.wallet.web3Provider();
|
const { provider, accounts, token } = await this.wallet.web3Provider();
|
||||||
this.provider = provider
|
this.provider = provider
|
||||||
this.market.updateProvider(provider);
|
this.market.updateProvider(provider);
|
||||||
this.store.walletType = walletType;
|
this.store.walletType = walletType;
|
||||||
this.store.address = accounts[0];
|
this.store.address = accounts[0];
|
||||||
|
this.token = token
|
||||||
this.store.$persist();
|
this.store.$persist();
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -72,6 +75,7 @@ export class BlockChain {
|
|||||||
this.wallet = new allProviders[result.wallet]();
|
this.wallet = new allProviders[result.wallet]();
|
||||||
this.store.walletType = result.wallet;
|
this.store.walletType = result.wallet;
|
||||||
this.store.address = result.accounts[0];
|
this.store.address = result.accounts[0];
|
||||||
|
this.token = token
|
||||||
this.store.$persist();
|
this.store.$persist();
|
||||||
} else {
|
} else {
|
||||||
console.log(`select result : ${result.errmsg}`);
|
console.log(`select result : ${result.errmsg}`);
|
||||||
@ -80,6 +84,7 @@ export class BlockChain {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async logout() {
|
async logout() {
|
||||||
|
this.token = '';
|
||||||
this.store.reset();
|
this.store.reset();
|
||||||
this.store.$persist();
|
this.store.$persist();
|
||||||
await this.wallet.logout();
|
await this.wallet.logout();
|
||||||
|
@ -62,9 +62,9 @@ export class PassportWallet {
|
|||||||
const passportProvider = this.passportInstance.connectEvm();
|
const passportProvider = this.passportInstance.connectEvm();
|
||||||
const accounts = await passportProvider.request({ method: "eth_requestAccounts" });
|
const accounts = await passportProvider.request({ method: "eth_requestAccounts" });
|
||||||
const provider = new providers.Web3Provider(passportProvider);
|
const provider = new providers.Web3Provider(passportProvider);
|
||||||
let accessToken = await this.passportInstance.getAccessToken()
|
const token = await this.passportInstance.getAccessToken()
|
||||||
console.log(`accesstoken`, accessToken)
|
console.log(`accesstoken`, token)
|
||||||
return { provider, accounts };
|
return { provider, accounts, token };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
<div class="cards">
|
<div class="cards">
|
||||||
<div class="card-top" v-if="nftData" @click="toDetail">
|
<div class="card-top" v-if="nftData" @click="toDetail">
|
||||||
<div class="card-img">
|
<div class="card-img">
|
||||||
<img :src="nftData.nft.image" alt="图片">
|
<LazyLoadImg :src="nftData.nft.image" :src-placeholder="placeholderImg" alt="图片" />
|
||||||
</div>
|
</div>
|
||||||
<div class="card-name">
|
<div class="card-name">
|
||||||
<div>Cotnesford park</div>
|
<div>Cotnesford park</div>
|
||||||
@ -34,6 +34,8 @@ import BuyDialog from "@/components/Dialogs/buyDialog.vue"
|
|||||||
import {priceCalculated} from "@/configs/priceCalculate.js"
|
import {priceCalculated} from "@/configs/priceCalculate.js"
|
||||||
import { useDetailStore } from "@/store/detail"
|
import { useDetailStore } from "@/store/detail"
|
||||||
import { useImmutableStore } from "@/store/immutable"
|
import { useImmutableStore } from "@/store/immutable"
|
||||||
|
import LazyLoadImg from "@/components/lazyloadimg"
|
||||||
|
import placeholderImg from '@/assets/img/marketplace/GenesisHeroes_NFT.png'
|
||||||
import {
|
import {
|
||||||
useMarketplaceStore
|
useMarketplaceStore
|
||||||
} from "@/store/marketplace"
|
} from "@/store/marketplace"
|
||||||
|
101
src/components/lazyloadimg/index.js
Normal file
101
src/components/lazyloadimg/index.js
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
import { reactive, h, computed, ref, onMounted, onBeforeUnmount } from "vue";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
props: {
|
||||||
|
src: {
|
||||||
|
type: String,
|
||||||
|
required: true
|
||||||
|
},
|
||||||
|
srcPlaceholder: {
|
||||||
|
type: String,
|
||||||
|
default:
|
||||||
|
""
|
||||||
|
},
|
||||||
|
srcset: {
|
||||||
|
type: String
|
||||||
|
},
|
||||||
|
intersectionOptions: {
|
||||||
|
type: Object,
|
||||||
|
default: () => ({})
|
||||||
|
},
|
||||||
|
usePicture: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
inheritAttrs: false,
|
||||||
|
setup(props, { attrs, slots, emit }) {
|
||||||
|
const root = ref(null);
|
||||||
|
const state = reactive({
|
||||||
|
observer: null,
|
||||||
|
intersected: false,
|
||||||
|
loaded: false
|
||||||
|
});
|
||||||
|
|
||||||
|
// Computed
|
||||||
|
const srcImage = computed(() =>
|
||||||
|
state.intersected && props.src ? props.src : props.srcPlaceholder
|
||||||
|
);
|
||||||
|
const srcsetImage = computed(() =>
|
||||||
|
state.intersected && props.srcset ? props.srcset : false
|
||||||
|
);
|
||||||
|
|
||||||
|
// Methods
|
||||||
|
const load = () => {
|
||||||
|
if (
|
||||||
|
root.value &&
|
||||||
|
root.value.getAttribute("src") !== props.srcPlaceholder
|
||||||
|
) {
|
||||||
|
state.loaded = true;
|
||||||
|
emit("load", root.value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
const error = () => emit("error", root.value);
|
||||||
|
|
||||||
|
// Hooks
|
||||||
|
onMounted(() => {
|
||||||
|
if ("IntersectionObserver" in window) {
|
||||||
|
state.observer = new IntersectionObserver((entries) => {
|
||||||
|
const image = entries[0];
|
||||||
|
if (image.isIntersecting) {
|
||||||
|
state.intersected = true;
|
||||||
|
state.observer.disconnect();
|
||||||
|
emit("intersect");
|
||||||
|
}
|
||||||
|
}, props.intersectionOptions);
|
||||||
|
|
||||||
|
state.observer.observe(root.value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
onBeforeUnmount(() => {
|
||||||
|
if ("IntersectionObserver" in window && state.observer) {
|
||||||
|
state.observer.disconnect();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return () => {
|
||||||
|
const img = h("img", {
|
||||||
|
ref: root,
|
||||||
|
src: srcImage.value,
|
||||||
|
srcset: srcsetImage.value || null, // set to null explicitly if falsy
|
||||||
|
...attrs,
|
||||||
|
class: [
|
||||||
|
attrs.class,
|
||||||
|
"v-lazy-image",
|
||||||
|
{ "v-lazy-image-loaded": state.loaded }
|
||||||
|
],
|
||||||
|
onLoad: load,
|
||||||
|
onError: error
|
||||||
|
});
|
||||||
|
|
||||||
|
return props.usePicture
|
||||||
|
? h(
|
||||||
|
"picture",
|
||||||
|
{ ref: root, onLoad: load },
|
||||||
|
state.intersected ? [slots.default, img] : [img]
|
||||||
|
)
|
||||||
|
: img;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
};
|
@ -1,4 +1,5 @@
|
|||||||
import axios from 'axios'
|
import { BlockChain } from "@/components/chain/BlockChain";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const API_BASE = import.meta.env.VUE_APP_MKT_API
|
const API_BASE = import.meta.env.VUE_APP_MKT_API
|
||||||
@ -7,8 +8,7 @@ const net_id = import.meta.env.VUE_APP_NET_ID
|
|||||||
const toJson = res => res.json();
|
const toJson = res => res.json();
|
||||||
|
|
||||||
const httpPost = async (url, data) => {
|
const httpPost = async (url, data) => {
|
||||||
console.log(this.store.tokenId,'---------------------------------------')
|
const token = new BlockChain().token;
|
||||||
const token = localStorage.getItem('assessToken');
|
|
||||||
let headers = {"Content-Type": "application/json"};
|
let headers = {"Content-Type": "application/json"};
|
||||||
// let token = token;
|
// let token = token;
|
||||||
if (token) {
|
if (token) {
|
||||||
@ -23,7 +23,7 @@ const httpPost = async (url, data) => {
|
|||||||
|
|
||||||
|
|
||||||
const httpGet = async (url, data) => {
|
const httpGet = async (url, data) => {
|
||||||
const token = localStorage.getItem('assessToken');
|
const token = new BlockChain().token;
|
||||||
let headers = {"Content-Type": "application/json"};
|
let headers = {"Content-Type": "application/json"};
|
||||||
if (token) {
|
if (token) {
|
||||||
headers['Authorization'] = `Bearer ${token}`;
|
headers['Authorization'] = `Bearer ${token}`;
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
<div class="content">
|
<div class="content">
|
||||||
<div class="top-left">
|
<div class="top-left">
|
||||||
<div class="top-left-img">
|
<div class="top-left-img">
|
||||||
<img :src="detailData.image" alt="">
|
<LazyLoadImg :src="detailData.image" :src-placeholder="placeholderImg" alt="" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="top-right">
|
<div class="top-right">
|
||||||
@ -145,16 +145,18 @@ import { nftDetail } from "@/utils/marketplace"
|
|||||||
import {priceCalculated} from "@/configs/priceCalculate.js"
|
import {priceCalculated} from "@/configs/priceCalculate.js"
|
||||||
import { BlockChain } from "@/components/chain/BlockChain"
|
import { BlockChain } from "@/components/chain/BlockChain"
|
||||||
import {walletStore} from "@/store/wallet";
|
import {walletStore} from "@/store/wallet";
|
||||||
|
import LazyLoadImg from "@/components/lazyloadimg"
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const localWalletStore = walletStore()
|
const localWalletStore = walletStore()
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
address: String,
|
address: String,
|
||||||
tokenid: String
|
tokenid: String
|
||||||
})
|
})
|
||||||
|
import placeholderImg from '@/assets/img/marketplace/GenesisHeroes_NFT.png'
|
||||||
const detailData = ref(null)
|
const detailData = ref(null)
|
||||||
// const detailData = window.history.state.nftData
|
// const detailData = window.history.state.nftData
|
||||||
// console.log(detailData)
|
// console.log(detailData)
|
||||||
// const myAddress = localWalletStore.address
|
const myAddress = localWalletStore.address
|
||||||
// const nftAbilities = ref(detailData.detail)
|
// const nftAbilities = ref(detailData.detail)
|
||||||
|
|
||||||
// 购买
|
// 购买
|
||||||
|
Loading…
x
Reference in New Issue
Block a user