File "preview.js"

Full Path: /home/warrior1/public_html/wp-content/plugins/elementor/app/modules/kit-library/assets/js/pages/preview/preview.js
File size: 4.39 KB
MIME-type: text/x-java
Charset: utf-8

import ElementorLoading from 'elementor-app/molecules/elementor-loading';
import ItemHeader from '../../components/item-header';
import Layout from '../../components/layout';
import PageLoader from '../../components/page-loader';
import PreviewResponsiveControls from './preview-responsive-controls';
import useKit from '../../hooks/use-kit';
import usePageTitle from 'elementor-app/hooks/use-page-title';
import { PreviewIframe } from './preview-iframe';
import { useLocation, useNavigate } from '@reach/router';
import { useState, useMemo } from 'react';
import { appsEventTrackingDispatch } from 'elementor-app/event-track/apps-event-tracking';

import './preview.scss';

export const breakpoints = [
	{
		value: 'desktop',
		label: __( 'Desktop', 'elementor' ),
		style: {
			width: '100%',
			height: '100%',
		},
	},
	{
		value: 'tablet',
		label: __( 'Tablet', 'elementor' ),
		style: {
			marginTop: '30px',
			marginBottom: '30px',
			width: '768px',
			height: '1024px',
		},
	},
	{
		value: 'mobile',
		label: __( 'Mobile', 'elementor' ),
		style: {
			marginTop: '30px',
			marginBottom: '30px',
			width: '375px',
			height: '667px',
		},
	},
];

function useHeaderButtons( id, kitName ) {
	const navigate = useNavigate();
	const eventTracking = ( command, viewTypeClicked, eventType = 'click' ) => {
		appsEventTrackingDispatch(
			command,
			{
				kit_name: kitName,
				element_position: 'app_header',
				page_source: 'view demo',
				view_type_clicked: viewTypeClicked,
				event_type: eventType,
			},
		);
	};
	return useMemo( () => [
		{
			id: 'overview',
			text: __( 'Overview', 'elementor' ),
			hideText: false,
			variant: 'outlined',
			color: 'secondary',
			size: 'sm',
			onClick: () => {
				eventTracking( 'kit-library/view-overview-page', 'overview' );
				navigate( `/kit-library/overview/${ id }` );
			},
			includeHeaderBtnClass: false,
		},
	], [ id ] );
}

/**
 * Get preview url.
 *
 * @param {*} data
 * @return {null|string} Preview URL
 */
function usePreviewUrl( data ) {
	const location = useLocation();

	return useMemo( () => {
		if ( ! data ) {
			return null;
		}

		const documentId = new URLSearchParams( location.pathname.split( '?' )?.[ 1 ] ).get( 'document_id' ),
			utm = '?utm_source=kit-library&utm_medium=wp-dash&utm_campaign=preview',
			previewUrl = data.previewUrl ? data.previewUrl + utm : data.previewUrl;

		if ( ! documentId ) {
			return previewUrl;
		}

		const documentPreviewUrl = data.documents.find( ( item ) => item.id === parseInt( documentId ) )?.previewUrl || previewUrl;
		return documentPreviewUrl ? documentPreviewUrl + utm : documentPreviewUrl;
	}, [ location, data ] );
}

export default function Preview( props ) {
	const { data, isError, isLoading } = useKit( props.id );
	const [ isIframeLoading, setIsIframeLoading ] = useState( true );
	const headersButtons = useHeaderButtons( props.id, data && data.title );
	const previewUrl = usePreviewUrl( data );
	const [ activeDevice, setActiveDevice ] = useState( 'desktop' );
	const iframeStyle = useMemo(
		() => breakpoints.find( ( { value } ) => value === activeDevice ).style,
		[ activeDevice ],
	);
	const eventTracking = ( command, layout, elementPosition = null, eventType = 'click' ) => {
		appsEventTrackingDispatch(
			command,
			{
				kit_name: data.title,
				page_source: 'view demo',
				layout,
				element_position: elementPosition,
				event_type: eventType,
			},
		);
	};

	const onChange = ( device ) => {
		setActiveDevice( device );
		eventTracking( 'kit-library/responsive-controls', device, 'app_header' );
	};

	usePageTitle( {
		title: data
			? `${ __( 'Kit Library', 'elementor' ) } | ${ data.title }`
			// eslint-disable-next-line @wordpress/i18n-ellipsis
			: __( 'Loading...', 'elementor' ),
	} );

	if ( isError ) {
		// Will be caught by the App error boundary.
		throw new Error();
	}

	if ( isLoading ) {
		return <ElementorLoading />;
	}

	return (
		<Layout header={
			<ItemHeader
				model={ data }
				buttons={ headersButtons }
				centerColumn={ <PreviewResponsiveControls active={ activeDevice } onChange={ ( device ) => onChange( device ) } kitName={ data.title } /> }
				pageId="demo"
			/>
		}>
			{ isIframeLoading && <PageLoader className="e-kit-library__preview-loader" /> }
			{
				previewUrl &&
					<PreviewIframe
						previewUrl={ previewUrl }
						style={ iframeStyle }
						onLoaded={ () => setIsIframeLoading( false ) }
					/>
			}
		</Layout>
	);
}

Preview.propTypes = {
	id: PropTypes.string,
};