mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-31 04:31:15 -06:00 
			
		
		
		
	 b4ffa91cb4
			
		
	
	
		b4ffa91cb4
		
	
	
	
	
		
			
			Change-Id: I066c0e7f8ce87ec00b1141a1b44430444a819b42 (cherry picked from commit 05907a1a42da82737090d55046974d401f8af057)
		
			
				
	
	
		
			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 }; |