mirror of
				https://github.com/misskey-dev/misskey
				synced 2025-10-25 20:32:42 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /*
 | |
|  * SPDX-FileCopyrightText: syuilo and misskey-project
 | |
|  * SPDX-License-Identifier: AGPL-3.0-only
 | |
|  */
 | |
| 
 | |
| import type { Directive } from 'vue';
 | |
| 
 | |
| const mountings = new Map<Element, {
 | |
| 	resize: ResizeObserver;
 | |
| 	intersection?: IntersectionObserver;
 | |
| 	fn: (w: number, h: number) => void;
 | |
| }>();
 | |
| 
 | |
| function calc(src: Element) {
 | |
| 	const info = mountings.get(src);
 | |
| 	const height = src.clientHeight;
 | |
| 	const width = src.clientWidth;
 | |
| 
 | |
| 	if (!info) return;
 | |
| 
 | |
| 	// アクティベート前などでsrcが描画されていない場合
 | |
| 	if (!height) {
 | |
| 		// IntersectionObserverで表示検出する
 | |
| 		if (!info.intersection) {
 | |
| 			info.intersection = new IntersectionObserver(entries => {
 | |
| 				if (entries.some(entry => entry.isIntersecting)) calc(src);
 | |
| 			});
 | |
| 		}
 | |
| 		info.intersection.observe(src);
 | |
| 		return;
 | |
| 	}
 | |
| 	if (info.intersection) {
 | |
| 		info.intersection.disconnect();
 | |
| 		delete info.intersection;
 | |
| 	}
 | |
| 
 | |
| 	info.fn(width, height);
 | |
| }
 | |
| 
 | |
| type SizeCallback = (w: number, h: number) => void;
 | |
| 
 | |
| export const getSizeDirective = {
 | |
| 	mounted(src, binding) {
 | |
| 		const resize = new ResizeObserver((entries, observer) => {
 | |
| 			calc(src);
 | |
| 		});
 | |
| 		resize.observe(src);
 | |
| 
 | |
| 		mountings.set(src, { resize, fn: binding.value });
 | |
| 		calc(src);
 | |
| 	},
 | |
| 
 | |
| 	unmounted(src, binding) {
 | |
| 		binding.value(0, 0);
 | |
| 		const info = mountings.get(src);
 | |
| 		if (!info) return;
 | |
| 		info.resize.disconnect();
 | |
| 		if (info.intersection) info.intersection.disconnect();
 | |
| 		mountings.delete(src);
 | |
| 	},
 | |
| } as Directive<Element, SizeCallback>;
 |