✌️
This commit is contained in:
		
							parent
							
								
									a0833ca691
								
							
						
					
					
						commit
						9cb3882efa
					
				
					 2 changed files with 28 additions and 26 deletions
				
			
		| 
						 | 
				
			
			@ -4,7 +4,7 @@
 | 
			
		|||
		<x-banner :media="media" :key="media.id"/>
 | 
			
		||||
	</template>
 | 
			
		||||
	<div v-if="mediaList.filter(media => previewable(media)).length > 0" class="gird-container" ref="gridOuter">
 | 
			
		||||
		<div :data-count="mediaList.filter(media => previewable(media)).length" :style="gridHeight !== null ? { height: `${gridHeight}px` } : {}">
 | 
			
		||||
		<div :data-count="mediaList.filter(media => previewable(media)).length" :style="gridInnerStyle">
 | 
			
		||||
			<template v-for="media in mediaList">
 | 
			
		||||
				<x-video :video="media" :key="media.id" v-if="media.type.startsWith('video')"/>
 | 
			
		||||
				<x-image :image="media" :key="media.id" v-else-if="media.type.startsWith('image')" :raw="raw"/>
 | 
			
		||||
| 
						 | 
				
			
			@ -37,38 +37,39 @@ export default Vue.extend({
 | 
			
		|||
			type: Number
 | 
			
		||||
		}
 | 
			
		||||
	},
 | 
			
		||||
	computed: {
 | 
			
		||||
		gridHeight() {
 | 
			
		||||
			if (this.$refs.gridOuter) {
 | 
			
		||||
				if (this.$props.width) {
 | 
			
		||||
					return this.$props.width * 9 / 16;
 | 
			
		||||
				} else if (this.$refs.gridOuter.clientHeight) {
 | 
			
		||||
					return this.$refs.gridOuter.clientHeight;
 | 
			
		||||
				}
 | 
			
		||||
				return 287;
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			return null;
 | 
			
		||||
	data() {
 | 
			
		||||
		return {
 | 
			
		||||
			gridInnerStyle: {}
 | 
			
		||||
		}
 | 
			
		||||
	},
 | 
			
		||||
	/*mounted() {
 | 
			
		||||
		console.log(this.$props.width)
 | 
			
		||||
		//#region for Safari bug
 | 
			
		||||
		if (this.$refs.gridOuter) {
 | 
			
		||||
			if (this.$props.width) {
 | 
			
		||||
				this.$refs.gridInner.style.height = `${this.$props.width * 9 / 16}px`
 | 
			
		||||
			} else if (this.$refs.gridOuter.clientHeight) {
 | 
			
		||||
				this.$refs.gridInner.style.height = `${this.$refs.gridOuter.clientHeight}px`
 | 
			
		||||
			} else {
 | 
			
		||||
				this.$refs.gridInner.style.height = '287px';
 | 
			
		||||
	mounted() {
 | 
			
		||||
		// for Safari bug
 | 
			
		||||
		if (this.$refs.gridOuter.clientHeight) {
 | 
			
		||||
			this.gridInnerStyle = { height: `${this.$refs.gridOuter.clientHeight}px` }
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
		//#endregion
 | 
			
		||||
	},*/
 | 
			
		||||
	methods: {
 | 
			
		||||
		previewable(file) {
 | 
			
		||||
			return file.type.startsWith('video') || file.type.startsWith('image');
 | 
			
		||||
		}
 | 
			
		||||
	},
 | 
			
		||||
	watch: {
 | 
			
		||||
		width(width) {
 | 
			
		||||
			// for Safari bug
 | 
			
		||||
			if (this.$refs.gridOuter) {
 | 
			
		||||
				let height = 287
 | 
			
		||||
 | 
			
		||||
				if (width) {
 | 
			
		||||
					height = width * 9 / 16;
 | 
			
		||||
				} else if (this.$refs.gridOuter.clientHeight) {
 | 
			
		||||
					height = this.$refs.gridOuter.clientHeight;
 | 
			
		||||
				}
 | 
			
		||||
 | 
			
		||||
				this.gridInnerStyle = { height: `${height}px` }
 | 
			
		||||
			} else {
 | 
			
		||||
				this.gridInnerStyle = {}
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
});
 | 
			
		||||
</script>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -45,6 +45,7 @@ export default Vue.extend({
 | 
			
		|||
		};
 | 
			
		||||
	},
 | 
			
		||||
	mounted() {
 | 
			
		||||
		// for Safari bug
 | 
			
		||||
		this.width = this.$refs.i.getBoundingClientRect().width;
 | 
			
		||||
	}
 | 
			
		||||
});
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue