Cotnesford park
@@ -34,6 +34,8 @@ import BuyDialog from "@/components/Dialogs/buyDialog.vue"
import {priceCalculated} from "@/configs/priceCalculate.js"
import { useDetailStore } from "@/store/detail"
import { useImmutableStore } from "@/store/immutable"
+import LazyLoadImg from "@/components/lazyloadimg"
+import placeholderImg from '@/assets/img/marketplace/GenesisHeroes_NFT.png'
import {
useMarketplaceStore
} from "@/store/marketplace"
diff --git a/src/components/lazyloadimg/index.js b/src/components/lazyloadimg/index.js
new file mode 100644
index 0000000..4773ec9
--- /dev/null
+++ b/src/components/lazyloadimg/index.js
@@ -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;
+ };
+ }
+};
\ No newline at end of file
diff --git a/src/views/DetailView.vue b/src/views/DetailView.vue
index ba981f6..8df8cfb 100644
--- a/src/views/DetailView.vue
+++ b/src/views/DetailView.vue
@@ -5,7 +5,7 @@
-
![]()
+
@@ -145,12 +145,14 @@ import { nftDetail } from "@/utils/marketplace"
import {priceCalculated} from "@/configs/priceCalculate.js"
import { BlockChain } from "@/components/chain/BlockChain"
import {walletStore} from "@/store/wallet";
+import LazyLoadImg from "@/components/lazyloadimg"
const router = useRouter();
const localWalletStore = walletStore()
const props = defineProps({
address: String,
tokenid: String
})
+import placeholderImg from '@/assets/img/marketplace/GenesisHeroes_NFT.png'
const detailData = ref(null)
// const detailData = window.history.state.nftData
// console.log(detailData)