mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-11-02 20:51:23 -07:00 
			
		
		
		
	
		
			
				
	
	
		
			83 lines
		
	
	
		
			No EOL
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			No EOL
		
	
	
		
			2.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import { h, ref, onMounted, onUpdated, onBeforeUpdate, computed, onBeforeUnmount } from 'vue';
 | 
						|
import { uniqueClasses } from './utils.js';
 | 
						|
const SwiperSlide = {
 | 
						|
  name: 'SwiperSlide',
 | 
						|
  props: {
 | 
						|
    tag: {
 | 
						|
      type: String,
 | 
						|
      default: 'div'
 | 
						|
    },
 | 
						|
    swiperRef: {
 | 
						|
      type: Object,
 | 
						|
      required: false
 | 
						|
    },
 | 
						|
    zoom: {
 | 
						|
      type: Boolean,
 | 
						|
      default: undefined
 | 
						|
    },
 | 
						|
    virtualIndex: {
 | 
						|
      type: [String, Number],
 | 
						|
      default: undefined
 | 
						|
    }
 | 
						|
  },
 | 
						|
 | 
						|
  setup(props, {
 | 
						|
    slots
 | 
						|
  }) {
 | 
						|
    let eventAttached = false;
 | 
						|
    const {
 | 
						|
      swiperRef
 | 
						|
    } = props;
 | 
						|
    const slideElRef = ref(null);
 | 
						|
    const slideClasses = ref('swiper-slide');
 | 
						|
 | 
						|
    function updateClasses(swiper, el, classNames) {
 | 
						|
      if (el === slideElRef.value) {
 | 
						|
        slideClasses.value = classNames;
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    onMounted(() => {
 | 
						|
      if (!swiperRef.value) return;
 | 
						|
      swiperRef.value.on('_slideClass', updateClasses);
 | 
						|
      eventAttached = true;
 | 
						|
    });
 | 
						|
    onBeforeUpdate(() => {
 | 
						|
      if (eventAttached || !swiperRef || !swiperRef.value) return;
 | 
						|
      swiperRef.value.on('_slideClass', updateClasses);
 | 
						|
      eventAttached = true;
 | 
						|
    });
 | 
						|
    onUpdated(() => {
 | 
						|
      if (!slideElRef.value || !swiperRef || !swiperRef.value) return;
 | 
						|
 | 
						|
      if (swiperRef.value.destroyed) {
 | 
						|
        if (slideClasses.value !== 'swiper-slide') {
 | 
						|
          slideClasses.value = 'swiper-slide';
 | 
						|
        }
 | 
						|
      }
 | 
						|
    });
 | 
						|
    onBeforeUnmount(() => {
 | 
						|
      if (!swiperRef || !swiperRef.value) return;
 | 
						|
      swiperRef.value.off('_slideClass', updateClasses);
 | 
						|
    });
 | 
						|
    const slideData = computed(() => ({
 | 
						|
      isActive: slideClasses.value.indexOf('swiper-slide-active') >= 0 || slideClasses.value.indexOf('swiper-slide-duplicate-active') >= 0,
 | 
						|
      isVisible: slideClasses.value.indexOf('swiper-slide-visible') >= 0,
 | 
						|
      isDuplicate: slideClasses.value.indexOf('swiper-slide-duplicate') >= 0,
 | 
						|
      isPrev: slideClasses.value.indexOf('swiper-slide-prev') >= 0 || slideClasses.value.indexOf('swiper-slide-duplicate-prev') >= 0,
 | 
						|
      isNext: slideClasses.value.indexOf('swiper-slide-next') >= 0 || slideClasses.value.indexOf('swiper-slide-duplicate-next') >= 0
 | 
						|
    }));
 | 
						|
    return () => {
 | 
						|
      return h(props.tag, {
 | 
						|
        class: uniqueClasses(`${slideClasses.value}`),
 | 
						|
        ref: slideElRef,
 | 
						|
        'data-swiper-slide-index': props.virtualIndex
 | 
						|
      }, props.zoom ? h('div', {
 | 
						|
        class: 'swiper-zoom-container',
 | 
						|
        'data-swiper-zoom': typeof props.zoom === 'number' ? props.zoom : undefined
 | 
						|
      }, slots.default && slots.default(slideData.value)) : slots.default && slots.default(slideData.value));
 | 
						|
    };
 | 
						|
  }
 | 
						|
 | 
						|
};
 | 
						|
export { SwiperSlide }; |