Server : LiteSpeed
System : Linux server104.web-hosting.com 4.18.0-513.24.1.lve.1.el8.x86_64 #1 SMP Thu May 9 15:10:09 UTC 2024 x86_64
User : saleoqej ( 6848)
PHP Version : 8.0.30
Disable Function : NONE
Directory :  /home/saleoqej/public_html/wp-content/plugins/thrive-leads/blocks/src/
Upload File :
Current Directory [ Writeable ] Root Directory [ Writeable ]


Current File : /home/saleoqej/public_html/wp-content/plugins/thrive-leads/blocks/src/utils.js
import { __ } from '@wordpress/i18n';
import { SelectControl } from '@wordpress/components';
import thriveLogo from './thrive-logo';

const createElement = wp.element.createElement;

wp.domReady( function() {
	wp.blocks.updateCategory( 'thrive', { icon: thriveLogo } );
} );

/**
 * Once an block is update try to update the preview in gutenberg too
 */
window.addEventListener( 'storage', ( storageEvent ) => {
	if ( storageEvent.key && storageEvent.key.includes( 'tl_design' ) ) {
		const design = storageEvent.key.split( '-' )[ 1 ],
			iframes = document.getElementsByClassName( `tl-block-${ design }` );
		Array.prototype.forEach.call( iframes, ( iframe ) => {
			iframe.setAttribute(
				'src',
				`${ iframe.getAttribute(
					'src'
				) }?tl_design=${ generateRandomString() }`
			);
		} );
		localStorage.removeItem( storageEvent.key );
	}
} );

/**
 * Helper functions
 */

export function tveOuterHeight( el ) {
	if ( ! el ) {
		return 0;
	}
	let height = el.offsetHeight;
	const style = getComputedStyle( el );

	height += parseInt( style.marginTop ) + parseInt( style.marginBottom );
	return height;
}

export function generateRandomString( radix = 16 ) {
	return (
		new Date().getTime() + Math.floor( Math.random() * 100000 )
	).toString( radix );
}

export function getPreviewLink( link ) {
	return `${ link }${
		link.split( '?' )[ 1 ] ? '&' : '?'
	}tve_block_preview=1`;
}

export function renderSelect( opts, props, label ) {
	return createElement(
		'div',
		{ class: 'tl-block-select-wrapper' },

		createElement( SelectControl, {
			label: __( label, 'thrive-leads' ),
			options: opts,
			onChange( value ) {
				props.setAttributes( {
					selectedBlock: parseInt( value ),
				} );
			},
			value: props.attributes.selectedBlock,
		} )
	);
}