| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- import { getWindow } from 'ssr-window';
- export default function Resize(_ref) {
- let {
- swiper,
- on,
- emit
- } = _ref;
- const window = getWindow();
- let observer = null;
- let animationFrame = null;
- const resizeHandler = () => {
- if (!swiper || swiper.destroyed || !swiper.initialized) return;
- emit('beforeResize');
- emit('resize');
- };
- const createObserver = () => {
- if (!swiper || swiper.destroyed || !swiper.initialized) return;
- observer = new ResizeObserver(entries => {
- animationFrame = window.requestAnimationFrame(() => {
- const {
- width,
- height
- } = swiper;
- let newWidth = width;
- let newHeight = height;
- entries.forEach(_ref2 => {
- let {
- contentBoxSize,
- contentRect,
- target
- } = _ref2;
- if (target && target !== swiper.el) return;
- newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;
- newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;
- });
- if (newWidth !== width || newHeight !== height) {
- resizeHandler();
- }
- });
- });
- observer.observe(swiper.el);
- };
- const removeObserver = () => {
- if (animationFrame) {
- window.cancelAnimationFrame(animationFrame);
- }
- if (observer && observer.unobserve && swiper.el) {
- observer.unobserve(swiper.el);
- observer = null;
- }
- };
- const orientationChangeHandler = () => {
- if (!swiper || swiper.destroyed || !swiper.initialized) return;
- emit('orientationchange');
- };
- on('init', () => {
- if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {
- createObserver();
- return;
- }
- window.addEventListener('resize', resizeHandler);
- window.addEventListener('orientationchange', orientationChangeHandler);
- });
- on('destroy', () => {
- removeObserver();
- window.removeEventListener('resize', resizeHandler);
- window.removeEventListener('orientationchange', orientationChangeHandler);
- });
- }
|