HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: /var/www/html/delstar/wp-content/plugins/essential-grid/admin/views/grid-import-export.php
<?php
/**
 * @package   Essential_Grid
 * @author    ThemePunch <info@themepunch.com>
 * @link      https://www.essential-grid.com/
 * @copyright 2024 ThemePunch
 */

if( !defined( 'ABSPATH') ) exit();

$item_skin = new Essential_Grid_Item_Skin();
$item_ele = new Essential_Grid_Item_Element();
$nav_skin = new Essential_Grid_Navigation();
$metas = new Essential_Grid_Meta();
$import = new Essential_Grid_Import();
$export = new Essential_Grid_Export();

$grids = Essential_Grid_Db::get_essential_grids();
$skins = $item_skin->get_essential_item_skins();
$elements = $item_ele->get_essential_item_elements();
$navigation_skins = $nav_skin->get_essential_navigation_skins();
$custom_metas = $metas->get_all_meta();
$global_css = Essential_Grid_Global_Css::get_global_css_styles();

$token = wp_create_nonce("Essential_Grid_actions");

$add_cpt = Essential_Grid_Base::getCpt();

$pg = 'false';
$allGrids    = esg_sort_grids_alphabetical( $grids );
$allSkins    = esg_sort_grids_alphabetical( $skins );
$allElements = esg_sort_grids_alphabetical( $elements );
$allNavs     = esg_sort_grids_alphabetical( $navigation_skins );
$allMetas    = esg_sort_grids_alphabetical( $custom_metas );

$import_data = false;
if (isset($_FILES['import_file'])) {
	if ($_FILES['import_file']['error'] > 0) {
		echo '<div class="error"><p>'.esc_attr__('Import File Error: Invalid file or file size too big.', ESG_TEXTDOMAIN).'</p></div>';
	} else {
		$file_name = $_FILES['import_file']['name'];
		$ext = explode(".", $file_name);
		$file_ext = strtolower(end($ext));
		$file_size = $_FILES['import_file']['size'];
		if ($file_ext == "json") {
			$encode_data = file_get_contents($_FILES['import_file']['tmp_name']);
			$import_data = json_decode(esg_remove_utf8_bom($encode_data), true);
			if (is_null($import_data)) {
				$last_err = json_last_error();
				$last_err_msg = json_last_error_msg();
				echo '<div class="error"><p>Import File Error: ( '.$last_err .' ) '. $last_err_msg.'</p></div>';
			}
		}else {
			echo '<div class="error"><p>'.esc_attr__('Import File Error: Only .json extension supported.', ESG_TEXTDOMAIN).'</p></div>';
		}
	}

	if (!empty($import_data)) {
		//check import keys for data we cant process
		$import_keys = $import->get_import_keys();
		$import_data_keys = array_keys($import_data);
		$diff = array_diff($import_data_keys, $import_keys);
		if (!empty($diff)) {
			echo '<div class="error"><p>'.esc_attr__('Import File contain data that cannot be processed!', ESG_TEXTDOMAIN).' ( '.implode(',', $diff) .' ) </p></div>';

			$esg_addons = Essential_Grid_Addons::instance();
			$missing_addons = $esg_addons->check_import_keys($diff);
			foreach ($missing_addons as $handle => $keys) {
				$title = $esg_addons->get_addon_attr($handle, 'title', esc_html($handle));
				echo '<div class="error"><p>'
					. sprintf(
						/* translators: 1: addon title, 2: import keys */
						esc_html__( 'Please install "%1$s" addon to process "%2$s"', ESG_TEXTDOMAIN ),
						$title,
						esc_html($keys)
					)
					. '</p></div>';
			}
			
			foreach ($diff as $key) {
				unset($import_data[$key]);
			}
		}
	}
	
}

function esg_sort_grids_alphabetical_callback($a, $b)
{
	if (is_object($a) && is_object($b)) {
		$a_name = $a->name;
		$b_name = $b->name;
	} else if (is_array($a) && is_array($b)) {
		$a_name = $a['name'];
		$b_name = $b['name'];
	} else {
		return 0;
	}
	$a_name = strtolower(strval($a_name));
	$b_name = strtolower(strval($b_name));
	if ($a_name > $b_name) {
		return 1;
	} else if ($a_name < $b_name) {
		return -1;
	}
	return 0;
}

function esg_sort_grids_alphabetical($ar)
{
	if (!is_array($ar) || empty($ar)) {
		return $ar;
	}
	$arr = $ar;
	usort($arr, 'esg_sort_grids_alphabetical_callback'); // anonomous functions not backwards compatible
	return $arr;
}

function esg_remove_utf8_bom($text)
{
	$bom = pack('H*','EFBBBF');
	return preg_replace("/^$bom/", '', $text);
}

?>
	<h2 class="topheader"><?php echo esc_html(get_admin_page_title()); ?></h2>
	<div id="eg-global-settings-menu">
		<ul>
			<li class="selected-esg-setting" data-toshow="esg-import-settings"><i class="material-icons">publish</i><p><?php esc_html_e('Import', ESG_TEXTDOMAIN); ?></p></li><!--
			--><li data-toshow="esg-export-settings"><i class="material-icons">get_app</i><p><?php esc_html_e('Export', ESG_TEXTDOMAIN); ?></p></li><!--
			--><li data-toshow="esg-demo-datas"><i class="material-icons">style</i><p><?php esc_html_e('Demo Datas', ESG_TEXTDOMAIN); ?></p></li>
		</ul>
	</div>
	<div id="eg-grid-export-import-wrapper" class="esg-box">
		<div id="esg-demo-datas" class="esg-settings-container">
			<?php if($add_cpt == 'true' || $add_cpt === true){ ?>
			<div>
				<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Full Demo ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
				<div class="eg-cs-tbc eg-cs-tbc-padding">
					<div class="esg-btn esg-green" id="esg-import-demo-posts"><?php esc_html_e('Import Full Demo Data', ESG_TEXTDOMAIN); ?></div>
				</div>
			</div>
			<?php } ?>
			<div>
				<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Skins ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
				<div class="eg-cs-tbc eg-cs-tbc-padding">
					<a href="<?php echo admin_url('admin.php'); ?>?page=essential-grid-item-skin" class="esg-btn esg-purple" id="esg-download-skins"><?php esc_html_e('Download Fresh Skins', ESG_TEXTDOMAIN); ?></a>
				</div>
			</div>
		</div>
		<form id="esg-export-settings" class="esg-settings-container" method="POST" action="<?php echo admin_url('admin-ajax.php'); ?>?action=Essential_Grid_request_ajax">
			<input type="hidden" name="client_action" value="export_data">
			<input type="hidden" name="token" value="<?php echo esc_attr($token); ?>">
			
			<div class="esg-export-toggle-mode">
				<!-- EXPORT MODE -->
				<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Mode ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
				<div class="eg-cs-tbc eg-cs-tbc-padding">

					<div class="esg-togglebutton">
						<input type="checkbox" class="checkbox" />
						<div class="knobs">
							<div class="before"><?php esc_html_e('Export Single Grid', ESG_TEXTDOMAIN); ?></div>
							<div class="after"><?php esc_html_e('Export All Items ', ESG_TEXTDOMAIN); ?></div>
							<span></span>
						</div>
						<div class="layer"></div>
					</div>

					<div class="esg-export-single-grid-wrapper">
						<input type=text name="esg_export_grid_name" id="esg_export_grid_name" value="" placeholder="<?php esc_attr_e('Type grid name or handle', ESG_TEXTDOMAIN); ?>" />
					</div>
					
				</div>
			</div>
			
			<?php if(!empty($grids)) { ?>
				<div class="esg-export-section esg-export-grids">
					<!-- BASIC SETTINGS -->
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Grids', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li><div class="eg-li-intern-wrap"><input class="esg-switch-checkboxes-trigger" type="checkbox" name="export-grids" checked="checked" /><span><?php esc_html_e('All', ESG_TEXTDOMAIN); ?></span><span class="eg-amount-of-lis"></span></div>
								<ul class="eg-ie-sub-ul">
									<?php
									foreach($allGrids as $grid) {
										if (!Essential_Grid_Base::isValid()) {
											$params = json_decode($grid->params, true);
											$pg = Essential_Grid_Base::getVar($params, 'pg', 'false');
										}
										$resources = $export->getGridResources(
											$import, 
											[
												'grid' => $grid,
												'skins' => $skins,
												'navigation_skins' => $navigation_skins,
												'global_css' => $global_css
											]
										);
									?>
										<li>
											<div class="eg-li-intern-wrap">
												<input type="checkbox" name="export-grids-id[]" value="<?php echo esc_attr($grid->id); ?>" <?php echo ($pg != 'false' ? 'disabled' : 'checked="checked"'); ?>
													data-handle="<?php esc_attr_e($grid->handle); ?>"
													data-resources="<?php esc_attr_e(wp_json_encode($resources)); ?>"
												/>
												<span class="eg-tooltip-wrap <?php echo ($pg != 'false' ? 'disabled' : ''); ?>" 
														<?php echo ($pg != 'false' ? 'title="' . esc_attr__('Activate Essential Grid to export premium templates', ESG_TEXTDOMAIN) . '"' : ''); ?>>
													<?php echo esc_html($grid->name . ' [ ' . $grid->handle . ' ]'); ?>
												</span>
											</div>
										</li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>
			
			<?php if(!empty($skins)){ ?>
				<div class="esg-export-section esg-export-skins">
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Skins ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li><div class="eg-li-intern-wrap"><input class="esg-switch-checkboxes-trigger" type="checkbox" name="export-skins" checked="checked" /><span><?php esc_html_e('All', ESG_TEXTDOMAIN); ?></span><span class="eg-amount-of-lis"></span></div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($allSkins as $skin){ ?>
										<li><div class="eg-li-intern-wrap"><input type="checkbox" name="export-skins-id[]" checked="checked" value="<?php echo esc_attr($skin['id']); ?>" /><?php echo esc_html($skin['name']); ?></div></li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>
			
			<?php if(!empty($elements)){ ?>
				<div class="esg-export-section esg-export-elements">
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Elements', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li><div class="eg-li-intern-wrap"><input class="esg-switch-checkboxes-trigger" type="checkbox" name="export-elements" checked="checked" /><span><?php esc_html_e('All', ESG_TEXTDOMAIN); ?></span><span class="eg-amount-of-lis"></span></div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($allElements as $element){ ?>
										<li><div class="eg-li-intern-wrap"><input type="checkbox" name="export-elements-id[]" checked="checked" value="<?php echo esc_attr($element['id']); ?>" /><?php echo esc_html($element['name']); ?></div></li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>
			
			<?php if(!empty($navigation_skins)){ ?>
				<div class="esg-export-section esg-export-navigation-skins">
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Navigation Skins', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li><div class="eg-li-intern-wrap"><input class="esg-switch-checkboxes-trigger" type="checkbox" name="export-navigation-skins" checked="checked" /><span><?php esc_html_e('All', ESG_TEXTDOMAIN); ?></span><span class="eg-amount-of-lis"></span></div>
								<ul class="eg-ie-sub-ul">
								<?php foreach($allNavs as $skin){ ?>
									<li><div class="eg-li-intern-wrap"><input type="checkbox" name="export-navigation-skins-id[]" checked="checked" value="<?php echo esc_attr($skin['id']); ?>" /><?php echo esc_html($skin['name']); ?></div></li>
								<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>
			
			<?php if(!empty($custom_metas)){ ?>
				<div class="esg-export-section esg-export-custom-meta">
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Custom Metas', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li><div class="eg-li-intern-wrap"><input class="esg-switch-checkboxes-trigger" type="checkbox" name="export-custom-meta" checked="checked" /><span><?php esc_html_e('All', ESG_TEXTDOMAIN); ?></span><span class="eg-amount-of-lis"></span></div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($allMetas as $meta){ $type = ($meta['m_type'] == 'link') ? 'egl-' : 'eg-'; ?>
										<li><div class="eg-li-intern-wrap"><input type="checkbox" name="export-custom-meta-handle[]" checked="checked" value="<?php echo esc_attr($meta['handle']); ?>" /><?php echo $type . esc_html($meta['handle']); ?></div></li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>

				<div class="esg-export-section esg-export-global-css">
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Others', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li><div class="eg-li-intern-wrap"><input type="checkbox" name="export-global-styles" value="on" checked="checked" /><span><?php esc_html_e('Global Styles', ESG_TEXTDOMAIN); ?></span></div></li>
						</ul>
					</div>
				</div>

				<?php echo apply_filters('essgrid_export_form_output', ''); ?>
			
				<div>
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Export', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<input type="submit" id="eg-export-selected-settings" class="esg-btn esg-purple" value="<?php esc_attr_e('Export Selected', ESG_TEXTDOMAIN); ?>" />
					</div>
				</div>
		</form>

		<form id="esg-import-settings" class="esg-settings-container active-esc" method="post" enctype="multipart/form-data">
		<?php
		$is_open = 'closed';
		$is_vis = 'display:none;';
		if(!empty($import_data)){
			$is_open = 'open';
			$is_vis = '';

			if(!empty($import_data['grids']) && is_array($import_data['grids']))
				foreach($import_data['grids'] as $d_grid)
					echo '<input type="hidden" name="data-grids[]" value="' . base64_encode(json_encode($d_grid, true)) . '" />';

			if(!empty($import_data['skins']) && is_array($import_data['skins']))
				foreach($import_data['skins'] as $d_skin)
					echo '<input type="hidden" name="data-skins[]" value="' . base64_encode(json_encode($d_skin, true)) . '" />';

			if(!empty($import_data['elements']) && is_array($import_data['elements']))
				foreach($import_data['elements'] as $d_elements)
					echo '<input type="hidden" name="data-elements[]" value="' . base64_encode(json_encode($d_elements, true)) . '" />';

			if(!empty($import_data['navigation-skins']) && is_array($import_data['navigation-skins']))
				foreach($import_data['navigation-skins'] as $d_navigation_skins)
					echo '<input type="hidden" name="data-navigation-skins[]" value="' . base64_encode(json_encode($d_navigation_skins, true)) . '" />';

			if(!empty($import_data['custom-meta']) && is_array($import_data['custom-meta']))
				foreach($import_data['custom-meta'] as $d_custom_meta)
					echo '<input type="hidden" name="data-custom-meta[]" value="' . base64_encode(json_encode($d_custom_meta, true)) . '" />';

			if(isset($import_data['global-css']))
				echo '<input type="hidden" name="data-global-css" value="' . base64_encode($import_data['global-css']) . '" />';

			echo apply_filters('essgrid_import_form_hidden_inputs', '', $import_data);

		}
		
		if(!empty($import_data)){
			
			if(!empty($import_data['grids'])){ ?>
				<div> 
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Grids ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li>
								<div class="eg-li-intern-wrap">
									<input class="esg-switch-checkboxes-trigger" type="checkbox" name="import-grids" checked="checked" />
									<span class="eg-import-checkbox-action"><?php esc_html_e('Unselect ', ESG_TEXTDOMAIN);?></span>
									<span><?php esc_html_e('Grids', ESG_TEXTDOMAIN); ?></span>
									<span class="eg-amount-of-lis"></span>
									<span class="esg-f-right">
										<span class="esg-radio-overwrite"><input type="radio" class="esg-overwrite-all" name="grid-overwrite-all" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
										--><span><input type="radio" class="esg-overwrite-all" name="grid-overwrite-all" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
									</span>
									<div class="esg-clearfix"></div>
								</div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($import_data['grids'] as $grid_values){ ?>
										<li>
											<div class="eg-li-intern-wrap">
												<input class="eg-get-val" type="checkbox" name="import-grids-id[]" value="<?php echo esc_attr($grid_values['id']); ?>" checked="checked" />
												<?php echo esc_html($grid_values['name']); ?>
												<?php
												if(!empty($grids)){
													foreach($grids as $grid){
														if($grid->handle == $grid_values['handle']){
															//already exists in database, ask to append or overwrite
															?>
															<span class="esg-f-right">
																<span class="esg-radio-overwrite"><input type="radio" name="grid-overwrite-<?php echo esc_attr($grid_values['id']); ?>" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
																--><span><input type="radio" name="grid-overwrite-<?php echo esc_attr($grid_values['id']); ?>" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
															</span>
															<div class="esg-clearfix"></div>
															<?php
															break;
														}
													}
												}
												?>
											</div>
										</li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>

			<?php if(!empty($import_data['skins'])){ ?>
				<div> 
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Skins ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li>
								<div class="eg-li-intern-wrap">
									<input class="esg-switch-checkboxes-trigger" type="checkbox" name="import-skins" checked="checked" />
									<span class="eg-import-checkbox-action"><?php esc_html_e('Unselect ', ESG_TEXTDOMAIN);?></span>
									<span><?php esc_html_e('Skins', ESG_TEXTDOMAIN); ?></span>
									<span class="eg-amount-of-lis"></span>
									<span class="esg-f-right">
										<span class="esg-radio-overwrite"><input type="radio" class="esg-overwrite-all" name="skin-overwrite-all" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
										--><span><input type="radio" class="esg-overwrite-all" name="skin-overwrite-all" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
									</span>
									<div class="esg-clearfix"></div>
								</div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($import_data['skins'] as $skin){ ?>
										<li>
											<div class="eg-li-intern-wrap">
												<input class="eg-get-val" type="checkbox" name="import-skins-id[]" checked="checked" value="<?php echo esc_attr($skin['id']); ?>" />
												<?php echo esc_html($skin['name']); ?>
												<?php
												if(!empty($skins)){
													foreach($skins as $e_skin){
														if($skin['handle'] == $e_skin['handle']){
															//already exists in database, ask to append or overwrite
															?>
															<span class="esg-f-right">
																<span class="esg-radio-overwrite"><input type="radio" name="skin-overwrite-<?php echo esc_attr($skin['id']); ?>" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
																--><span><input type="radio" name="skin-overwrite-<?php echo esc_attr($skin['id']); ?>" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
															</span>
															<div class="esg-clearfix"></div>
															<?php
															break;
														}
													}
												}
												?>
											</div>
										</li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>

			<?php if(!empty($import_data['elements'])){ ?>
				<div> 
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Elements ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li>
								<div class="eg-li-intern-wrap">
									<input class="esg-switch-checkboxes-trigger" type="checkbox" name="import-elements" checked="checked" />
									<span class="eg-import-checkbox-action"><?php esc_html_e('Unselect ', ESG_TEXTDOMAIN);?></span>
									<span><?php esc_html_e('Elements', ESG_TEXTDOMAIN); ?></span>
									<span class="eg-amount-of-lis"></span>
									<span class="esg-f-right">
										<span class="esg-radio-overwrite"><input type="radio" class="esg-overwrite-all" name="element-overwrite-all" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
										--><span><input type="radio" class="esg-overwrite-all" name="element-overwrite-all" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
									</span>
									<div class="esg-clearfix"></div>
								</div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($import_data['elements'] as $element){ ?>
										<li>
											<div class="eg-li-intern-wrap">
												<input class="eg-get-val" type="checkbox" name="import-elements-id[]" checked="checked" value="<?php echo esc_attr($element['id']); ?>" />
												<?php echo esc_html($element['name']); ?>
												<?php
												if(!empty($elements)){
													foreach($elements as $e_element){
														if($element['handle'] == $e_element['handle']){
															//already exists in database, ask to append or overwrite
															?>
															<span class="esg-f-right">
																<span class="esg-radio-overwrite"><input type="radio" name="element-overwrite-<?php echo esc_attr($element['id']); ?>" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
																--><span><input type="radio" name="element-overwrite-<?php echo esc_attr($element['id']); ?>" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
															</span>
															<div class="esg-clearfix"></div>
															<?php
															break;
														}
													}
												}
												?>
											</div>
										</li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>

			<?php if(!empty($import_data['navigation-skins'])){ ?>
				<div> 
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Navigation Skins ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li>
								<div class="eg-li-intern-wrap">
									<input class="esg-switch-checkboxes-trigger" type="checkbox" name="import-navigation-skins" checked="checked" />
									<span class="eg-import-checkbox-action"><?php esc_html_e('Unselect ', ESG_TEXTDOMAIN);?></span>
									<span><?php esc_html_e('Navigation Skins', ESG_TEXTDOMAIN); ?></span>
									<span class="eg-amount-of-lis"></span>
									<span class="esg-f-right">
										<span class="esg-radio-overwrite"><input type="radio" class="esg-overwrite-all" name="nav-skin-overwrite-all" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
										--><span><input type="radio" class="esg-overwrite-all" name="nav-skin-overwrite-all" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
									</span>
									<div class="esg-clearfix"></div>
								</div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($import_data['navigation-skins'] as $skin){ ?>
										<li>
											<div class="eg-li-intern-wrap">
												<input class="eg-get-val" type="checkbox" name="import-navigation-skins-id[]" checked="checked" value="<?php echo esc_attr($skin['id']); ?>" />
												<?php echo esc_html($skin['name']); ?>
												<?php
												if(!empty($navigation_skins)){
													foreach($navigation_skins as $e_nav_skins){
														if($skin['handle'] == $e_nav_skins['handle']){
															//already exists in database, ask to append or overwrite
															?>
															<span class="esg-f-right">
																<span class="esg-radio-overwrite"><input type="radio" name="nav-skin-overwrite-<?php echo esc_attr($skin['id']); ?>" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
																--><span><input type="radio" name="nav-skin-overwrite-<?php echo esc_attr($skin['id']); ?>" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
															</span>
															<div class="esg-clearfix"></div>
															<?php
															break;
														}
													}
												}
												?>
											</div>
										</li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>

			<?php if(!empty($import_data['custom-meta'])){ ?>
				<div> 
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Custom Meta ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li>
								<div class="eg-li-intern-wrap">
									<input class="esg-switch-checkboxes-trigger" type="checkbox" name="import-custom-meta" checked="checked" />
									<span class="eg-import-checkbox-action"><?php esc_html_e('Unselect ', ESG_TEXTDOMAIN);?></span>
									<span><?php esc_html_e('Custom Meta', ESG_TEXTDOMAIN); ?></span>
									<span class="eg-amount-of-lis"></span>
									<span class="esg-f-right">
										<span class="esg-radio-overwrite"><input type="radio" class="esg-overwrite-all" name="custom-meta-overwrite-all" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
										--><span><input type="radio" class="esg-overwrite-all" name="custom-meta-overwrite-all" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
									</span>
									<div class="esg-clearfix"></div>
								</div>
								<ul class="eg-ie-sub-ul">
									<?php foreach($import_data['custom-meta'] as $custom_meta){ ?>
										<li>
											<div class="eg-li-intern-wrap">
												<input class="eg-get-val" type="checkbox" name="import-custom-meta-handle[]" checked="checked" value="<?php echo esc_attr($custom_meta['handle']); ?>" />
												<?php echo esc_html($custom_meta['handle']); ?>
												<?php
												if(!empty($custom_metas)){
													foreach($custom_metas as $e_custom_meta){
														if($custom_meta['handle'] == $e_custom_meta['handle']){
															//already exists in database, ask to append or overwrite
															?>
															<span class="esg-f-right">
																<span class="esg-radio-overwrite"><input type="radio" name="custom-meta-overwrite-<?php echo esc_attr($custom_meta['handle']); ?>" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
																--><span><input type="radio" name="custom-meta-overwrite-<?php echo esc_attr($custom_meta['handle']); ?>" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
															</span>
															<div class="esg-clearfix"></div>
															<?php
															break;
														}
													}
												}
												?>
											</div>
										</li>
									<?php } ?>
								</ul>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>

			<?php if(!empty($import_data['global-css'])){ ?>
				<div> 
					<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Global CSS ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
					<div class="eg-cs-tbc eg-cs-tbc-padding">
						<ul>
							<li>
								<div class="eg-li-intern-wrap">
									<input class="eg-get-val" type="checkbox" name="import-global-styles" checked="checked"/><!--
									--><span><?php esc_html_e('Global Styles', ESG_TEXTDOMAIN); ?></span>
									<span class="esg-f-right">
										<span class="esg-radio-overwrite"><input type="radio" name="global-styles-overwrite" checked="checked" value="append" /> <?php esc_html_e('Append as New', ESG_TEXTDOMAIN); ?></span><span class="space18"></span><!--
										--><span><input type="radio" name="global-styles-overwrite" value="overwrite" /> <?php esc_html_e('Overwrite Existing', ESG_TEXTDOMAIN); ?></span>
									</span>
									<div class="esg-clearfix"></div>
								</div>
							</li>
						</ul>
					</div>
				</div>
			<?php } ?>

			<?php echo apply_filters('essgrid_import_form_output', '', $import_data); ?>

			<div>
				<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Additional', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
				<div class="eg-cs-tbc eg-cs-tbc-padding">
					<ul>
						<li>
							<div class="eg-li-intern-wrap">
								<input class="eg-get-val" type="checkbox" name="import-create-taxonomies" /><!--
									--><span><?php esc_html_e('Create Missing Taxonomies', ESG_TEXTDOMAIN); ?></span>
								<div><?php esc_html_e('Create missing categories and tags for post-based grid.', ESG_TEXTDOMAIN); ?> 
									<?php esc_html_e('(New categories and tags will have no assigned posts; you will need to assign them.)', ESG_TEXTDOMAIN); ?></div>
								<div class="esg-clearfix"></div>
							</div>
						</li>
					</ul>
				</div>
			</div>

			<div>
				<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Import ', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
				<div class="eg-cs-tbc eg-cs-tbc-padding">
					<div id="esg-import-data" class="esg-btn esg-purple"><?php esc_html_e('Import Selected Data', ESG_TEXTDOMAIN); ?></div>
				</div>
			</div>
		<?php
		} else { ?>
			<div>
				<div class="eg-cs-tbc-left"><esg-llabel><span><?php esc_html_e('Select File', ESG_TEXTDOMAIN); ?></span></esg-llabel></div>
				<div class="eg-cs-tbc eg-cs-tbc-padding">
					<input type="file" name="import_file" />
					<div class="div13"></div>
					<input type="submit" class="esg-btn esg-purple" id="esg-read-file-import" value="<?php esc_attr_e('Read Selected File', ESG_TEXTDOMAIN); ?>" />
				</div>
			</div>
		<?php } ?>
		</form>
	</div>

<script type="text/javascript">
	window.ESG ??={};
	ESG.F ??= {};
	ESG.E ??= {};
	ESG.V ??= {};
	ESG.S ??= {};
	ESG.C ??= {};
	ESG.LIB = ESG.LIB===undefined ? { nav_skins:[], item_skins:{}, nav_originals:{}} : ESG.LIB;
	ESG.CM = ESG.CM===undefined ? {apiJS:null, ajaxCSS:null, navCSS:null} : ESG.CM;
	ESG.WIN ??=jQuery(window);
	ESG.DOC ??=jQuery(document);

	ESG.E.waitTptFunc ??= [];
	ESG.E.waitTptFunc.push(function(){
		jQuery(function(){ AdminEssentials.initImportExport(); });
	});
</script>