public function export_skins($export_skins) { $return_skins = array(); if ($export_skins !== false && !empty($export_skins)) { $item_skin = new Essential_Grid_Item_Skin(); $skins = $item_skin->get_essential_item_skins('all', false); //false = do not decode params if (!empty($skins)) { foreach ($export_skins as $e_skin_id) { foreach ($skins as $skin) { if ($e_skin_id == $skin['id']) { $return_skins[] = $skin; break; } } } } } return $return_skins; }
/** * output the demo skin html */ public static function output_demo_skin_html($data) { $grid = new Essential_Grid(); $base = new Essential_Grid_Base(); $item_skin = new Essential_Grid_Item_Skin(); if (!isset($data['postparams']['source-type'])) { //something is wrong, print error return array('error' => __('Something went wrong, this may have to do with Server limitations', EG_TEXTDOMAIN)); } $html = ''; $preview = ''; $preview_type = $data['postparams']['source-type'] == 'custom' ? 'custom' : 'preview'; $grid_id = isset($data['id']) && intval($data['id']) > 0 ? intval($data['id']) : '-1'; ob_start(); $grid->output_essential_grid($grid_id, $data, $preview_type); $html = ob_get_contents(); ob_clean(); ob_end_clean(); $skin = $base->getVar($data['params'], 'entry-skin', 0, 'i'); if ($skin > 0) { ob_start(); $item_skin->init_by_id($skin); $item_skin->output_item_skin('custom'); $preview = ob_get_contents(); ob_clean(); ob_end_clean(); } return array('html' => $html, 'preview' => $preview); }
$demo_img = array(); for ($i = 1; $i <= 18; $i++) { $demo_img[] = 'demoimage1.jpg'; } if (!empty($skins) && is_array($skins)) { $src = array(); $do_only_first = false; if ($entry_skin_choosen == '0') { $do_only_first = true; } //only add the selected on the first element if we create a new grid, so we select the firs skin foreach ($skins as $skin) { if (empty($src)) { $src = $demo_img; } $item_skin = new Essential_Grid_Item_Skin(); $item_skin->init_by_data($skin); //set filters $item_skin->set_skin_choose_filter(); //set demo image $img_key = array_rand($src); $item_skin->set_image($src[$img_key]); unset($src[$img_key]); $item_filter = $item_skin->get_filter_array(); $filters = array_merge($item_filter, $filters); ob_start(); if ($do_only_first) { $item_skin->output_item_skin('skinchoose', '-1'); //-1 = will do select $do_only_first = false; } else {
/** * Handle Ajax Requests */ public static function on_ajax_action() { try { $token = self::getPostVar('token', false); //verify the token $isVerified = wp_verify_nonce($token, 'Essential_Grid_actions'); $error = false; if ($isVerified) { $data = self::getPostVar("data", false); switch (self::getPostVar("client_action", false)) { case 'add_google_fonts': $f = new ThemePunch_Fonts(); $result = $f->add_new_font($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Font successfully created!", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getFontsUrl())); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'remove_google_fonts': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('Font not found', EG_TEXTDOMAIN), false); } $f = new ThemePunch_Fonts(); $result = $f->remove_font_by_handle($data['handle']); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Font successfully removed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'edit_google_fonts': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('No handle given', EG_TEXTDOMAIN), false); } if (!isset($data['url'])) { Essential_Grid::ajaxResponseError(__('No parameters given', EG_TEXTDOMAIN), false); } $f = new ThemePunch_Fonts(); $result = $f->edit_font_by_handle($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Font successfully changed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'add_custom_meta': $m = new Essential_Grid_Meta(); $result = $m->add_new_meta($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Meta successfully created!", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getSubViewUrl(Essential_Grid_Admin::VIEW_SUB_CUSTOM_META_AJAX))); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'remove_custom_meta': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('Meta not found', EG_TEXTDOMAIN), false); } $m = new Essential_Grid_Meta(); $result = $m->remove_meta_by_handle($data['handle']); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Meta successfully removed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'edit_custom_meta': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('No handle given', EG_TEXTDOMAIN), false); } if (!isset($data['name'])) { Essential_Grid::ajaxResponseError(__('No name given', EG_TEXTDOMAIN), false); } $m = new Essential_Grid_Meta(); $result = $m->edit_meta_by_handle($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Meta successfully changed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'add_link_meta': $m = new Essential_Grid_Meta_Linking(); $result = $m->add_new_link_meta($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Meta successfully created!", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getSubViewUrl(Essential_Grid_Admin::VIEW_SUB_CUSTOM_META_AJAX))); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'remove_link_meta': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('Meta not found', EG_TEXTDOMAIN), false); } $m = new Essential_Grid_Meta_Linking(); $result = $m->remove_link_meta_by_handle($data['handle']); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Meta successfully removed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'edit_link_meta': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('No handle given', EG_TEXTDOMAIN), false); } if (!isset($data['name'])) { Essential_Grid::ajaxResponseError(__('No name given', EG_TEXTDOMAIN), false); } if (!isset($data['original'])) { Essential_Grid::ajaxResponseError(__('No original given', EG_TEXTDOMAIN), false); } $m = new Essential_Grid_Meta_Linking(); $result = $m->edit_link_meta_by_handle($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Meta successfully changed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'add_widget_area': $wa = new Essential_Grid_Widget_Areas(); $result = $wa->add_new_sidebar($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Widget Area successfully created!", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getSubViewUrl(Essential_Grid_Admin::VIEW_SUB_WIDGET_AREA_AJAX))); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'edit_widget_area': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('No handle given', EG_TEXTDOMAIN), false); } if (!isset($data['name'])) { Essential_Grid::ajaxResponseError(__('No name given', EG_TEXTDOMAIN), false); } $wa = new Essential_Grid_Widget_Areas(); $result = $wa->edit_widget_area_by_handle($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Widget Area successfully changed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'remove_widget_area': if (!isset($data['handle'])) { Essential_Grid::ajaxResponseError(__('Widget Area not found', EG_TEXTDOMAIN), false); } $wa = new Essential_Grid_Widget_Areas(); $result = $wa->remove_widget_area_by_handle($data['handle']); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Widget Area successfully removed!", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseError($result, false); } break; case 'get_preview_html_markup': //add wpml transient $lang_code = ''; if (Essential_Grid_Wpml::is_wpml_exists()) { $lang_code = Essential_Grid_Wpml::get_current_lang_code(); } if (isset($data['id'])) { delete_transient('ess_grid_trans_query_' . $data['id'] . $lang_code); //delete cache } $result = Essential_Grid_Base::output_demo_skin_html($data); if (isset($result['error'])) { Essential_Grid::ajaxResponseData($result); } else { Essential_Grid::ajaxResponseData(array("data" => array('html' => $result['html'], 'preview' => @$result['preview']))); } break; /* //TP: CHUNK case 'get_preview_html_markup_chunk': //only for custom grid $grid = new Essential_Grid(); $grid->init_by_data($data); $html = ''; if($grid->is_custom_grid()){ ob_start(); $grid->output_by_custom('custom', true); $html = ob_get_contents(); ob_clean(); ob_end_clean(); } $order_id = self::getPostVar("order_id", false); Essential_Grid::ajaxResponseData(array("data"=>array('preview' => $html, 'order_id' => $order_id))); break; */ /* //TP: CHUNK case 'get_preview_html_markup_chunk': //only for custom grid $grid = new Essential_Grid(); $grid->init_by_data($data); $html = ''; if($grid->is_custom_grid()){ ob_start(); $grid->output_by_custom('custom', true); $html = ob_get_contents(); ob_clean(); ob_end_clean(); } $order_id = self::getPostVar("order_id", false); Essential_Grid::ajaxResponseData(array("data"=>array('preview' => $html, 'order_id' => $order_id))); break; */ case 'save_search_settings': if (!empty($data)) { update_option('esg-search-settings', $data); } Essential_Grid::ajaxResponseSuccess(__("Search Settings succesfully saved!", EG_TEXTDOMAIN)); break; case 'update_general_settings': $result = self::savePluginPermission($data['permission']); $cur_query = get_option('tp_eg_query_type', 'wp_query'); update_option('tp_eg_output_protection', @$data['protection']); update_option('tp_eg_tooltips', @$data['tooltips']); update_option('tp_eg_wait_for_fonts', @$data['wait_for_fonts']); update_option('tp_eg_js_to_footer', @$data['js_to_footer']); update_option('tp_eg_use_cache', @$data['use_cache']); update_option('tp_eg_query_type', @$data['query_type']); update_option('tp_eg_enable_log', @$data['enable_log']); update_option('tp_eg_use_lightbox', @$data['use_lightbox']); if (@$data['use_lightbox'] === 'jackbox') { Essential_Grid_Jackbox::enable_jackbox(); } else { Essential_Grid_Jackbox::disable_jackbox(); } if ($cur_query !== $data['query_type']) { //delete cache $lang = array(); if (Essential_Grid_Wpml::is_wpml_exists()) { $lang = icl_get_languages(); } $grids = Essential_Grid::get_essential_grids(); if (!empty($grids)) { foreach ($grids as $grid) { if (!empty($lang)) { foreach ($lang as $code => $val) { delete_transient('ess_grid_trans_query_' . $grid->id . $val['language_code']); delete_transient('ess_grid_trans_full_grid_' . $grid->id . $val['language_code']); } } else { delete_transient('ess_grid_trans_query_' . $grid->id); delete_transient('ess_grid_trans_full_grid_' . $grid->id); } } } } if ($result !== true) { $error = __("Global Settings did not change!", EG_TEXTDOMAIN); } else { Essential_Grid::ajaxResponseSuccess(__("Global Settings succesfully saved!", EG_TEXTDOMAIN), $result); } break; case 'update_create_grid': $result = self::update_create_grid($data); if ($result !== true) { $error = $result; } else { $lang = array(); if (Essential_Grid_Wpml::is_wpml_exists()) { $lang = icl_get_languages(); } if (isset($data['id']) && intval($data['id']) > 0) { if (!empty($lang)) { foreach ($lang as $code => $val) { delete_transient('ess_grid_trans_query_' . $data['id'] . $val['language_code']); //delete cache delete_transient('ess_grid_trans_full_grid_' . $data['id'] . $val['language_code']); //delete cache } } else { delete_transient('ess_grid_trans_query_' . $data['id']); //delete cache delete_transient('ess_grid_trans_full_grid_' . $data['id']); //delete cache } Essential_Grid::ajaxResponseSuccess(__("Grid successfully saved/changed!", EG_TEXTDOMAIN), $result); } else { Essential_Grid::ajaxResponseSuccess(__("Grid successfully saved/changed!", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getViewUrl(Essential_Grid_Admin::VIEW_OVERVIEW))); } } break; case 'delete_grid': $result = self::delete_grid_by_id($data); if ($result !== true) { $error = $result; } else { Essential_Grid::ajaxResponseSuccess(__("Grid deleted", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getViewUrl(Essential_Grid_Admin::VIEW_OVERVIEW))); } break; case 'duplicate_grid': $result = self::duplicate_grid_by_id($data); if ($result !== true) { $error = $result; } else { Essential_Grid::ajaxResponseSuccess(__("Grid duplicated", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getViewUrl(Essential_Grid_Admin::VIEW_OVERVIEW))); } break; case 'update_create_item_skin': $result = Essential_Grid_Item_Skin::update_save_item_skin($data); if ($result !== true) { $error = $result; } else { if (isset($data['id']) && intval($data['id']) > 0) { Essential_Grid::ajaxResponseSuccess(__("Item Skin changed", EG_TEXTDOMAIN), array('data' => $result)); } else { Essential_Grid::ajaxResponseSuccess(__("Item Skin created/changed", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getViewUrl("", "", 'essential-' . Essential_Grid_Admin::VIEW_SUB_ITEM_SKIN_OVERVIEW))); } } break; case 'update_custom_css': if (isset($data['global_css'])) { Essential_Grid_Global_Css::set_global_css_styles($data['global_css']); Essential_Grid::ajaxResponseSuccess(__("CSS saved!", EG_TEXTDOMAIN), ''); } else { $error = __("No CSS Received", EG_TEXTDOMAIN); } break; case 'delete_item_skin': $result = Essential_Grid_Item_Skin::delete_item_skin_by_id($data); if ($result !== true) { $error = $result; } else { Essential_Grid::ajaxResponseSuccess(__("Item Skin deleted", EG_TEXTDOMAIN), array('data' => $result)); } break; case 'duplicate_item_skin': $result = Essential_Grid_Item_Skin::duplicate_item_skin_by_id($data); if ($result !== true) { $error = $result; } else { Essential_Grid::ajaxResponseSuccess(__("Item Skin duplicated", EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getViewUrl("", "", 'essential-' . Essential_Grid_Admin::VIEW_SUB_ITEM_SKIN_OVERVIEW))); } break; case 'star_item_skin': $result = Essential_Grid_Item_Skin::star_item_skin_by_id($data); if ($result !== true) { $error = $result; } else { Essential_Grid::ajaxResponseSuccess(__("Favorite Changed", EG_TEXTDOMAIN), array('data' => $result)); } break; case 'update_create_item_element': $result = Essential_Grid_Item_Element::update_create_essential_item_element($data); if ($result !== true) { $error = $result; } else { Essential_Grid::ajaxResponseSuccess(__("Item Element created/changed", EG_TEXTDOMAIN), array('data' => $result)); } break; case 'check_item_element_existence': $result = Essential_Grid_Item_Element::check_existence_by_handle(@$data['name']); if ($result === false) { Essential_Grid::ajaxResponseData(array("data" => array('existence' => 'false'))); } elseif ($result === true) { Essential_Grid::ajaxResponseData(array("data" => array('existence' => 'true'))); } else { Essential_Grid::ajaxResponseData(array("data" => array('existence' => $result))); } break; case 'get_predefined_elements': $elements = Essential_Grid_Item_Element::getElementsForJavascript(); $html_elements = Essential_Grid_Item_Element::prepareDefaultElementsForEditor(); $html_elements .= Essential_Grid_Item_Element::prepareTextElementsForEditor(); Essential_Grid::ajaxResponseData(array("data" => array('elements' => $elements, 'html' => $html_elements))); break; case 'delete_predefined_elements': $result = Essential_Grid_Item_Element::delete_element_by_handle($data); if ($result !== true) { $error = $result; } else { Essential_Grid::ajaxResponseSuccess(__("Item Element successfully deleted", EG_TEXTDOMAIN), array('data' => $result)); } break; case 'update_create_navigation_skin_css': $nav = new Essential_Grid_Navigation(); $result = $nav->update_create_navigation_skin_css($data); if ($result !== true) { $error = $result; } else { $base = new Essential_Grid_Base(); $skin_css = Essential_Grid_Navigation::output_navigation_skins(); $skins = Essential_Grid_Navigation::get_essential_navigation_skins(); $select = ''; foreach ($skins as $skin) { $select .= '<option value="' . $skin['handle'] . '">' . $skin['name'] . '</option>' . "\n"; } if (isset($data['sid']) && intval($data['sid']) > 0) { Essential_Grid::ajaxResponseSuccess(__("Navigation Skin successfully changed!", EG_TEXTDOMAIN), array('css' => $skin_css, 'select' => $select, 'default_skins' => $skins)); } else { Essential_Grid::ajaxResponseSuccess(__("Navigation Skin successfully created", EG_TEXTDOMAIN), array('css' => $skin_css, 'select' => $select, 'default_skins' => $skins)); } } break; case 'delete_navigation_skin_css': $nav = new Essential_Grid_Navigation(); $result = $nav->delete_navigation_skin_css($data); if ($result !== true) { $error = $result; } else { $base = new Essential_Grid_Base(); $skin_css = Essential_Grid_Navigation::output_navigation_skins(); $skins = Essential_Grid_Navigation::get_essential_navigation_skins(); $select = ''; foreach ($skins as $skin) { $select .= '<option value="' . $skin['handle'] . '">' . $skin['name'] . '</option>' . "\n"; } Essential_Grid::ajaxResponseSuccess(__("Navigation Skin successfully deleted!", EG_TEXTDOMAIN), array('css' => $skin_css, 'select' => $select, 'default_skins' => $skins)); } break; case 'get_post_meta_html_for_editor': if (!isset($data['post_id']) || intval($data['post_id']) == 0) { Essential_Grid::ajaxResponseError(__('No Post ID/Wrong Post ID!', EG_TEXTDOMAIN), false); exit; } if (!isset($data['grid_id']) || intval($data['grid_id']) == 0) { Essential_Grid::ajaxResponseError(__('Please save the grid first to use this feature!', EG_TEXTDOMAIN), false); exit; } $post = get_post($data['post_id']); $disable_advanced = true; //nessecary, so that only normal things can be changed in preview mode if (!empty($post)) { $grid_id = $data['grid_id']; ob_start(); require 'views/elements/grid-meta-box.php'; $content = ob_get_contents(); ob_clean(); ob_end_clean(); Essential_Grid::ajaxResponseData(array("data" => array('html' => $content))); } else { Essential_Grid::ajaxResponseError(__('Post not found!', EG_TEXTDOMAIN), false); exit; } break; case 'update_post_meta_through_editor': if (!isset($data['metas']) || !isset($data['metas']['post_id']) || intval($data['metas']['post_id']) == 0) { Essential_Grid::ajaxResponseError(__('No Post ID/Wrong Post ID!', EG_TEXTDOMAIN), false); exit; } if (!isset($data['metas']) || !isset($data['metas']['grid_id']) || intval($data['metas']['grid_id']) == 0) { Essential_Grid::ajaxResponseError(__('Please save the grid first to use this feature!', EG_TEXTDOMAIN), false); exit; } //set the cobbles setting to the post $cobbles = json_decode(get_post_meta($data['metas']['post_id'], 'eg_cobbles', true), true); $cobbles[$data['metas']['grid_id']]['cobbles'] = $data['metas']['eg_cobbles_size']; $cobbles = json_encode($cobbles); update_post_meta($data['metas']['post_id'], 'eg_cobbles', $cobbles); //set the use_skin setting to the post $use_skin = json_decode(get_post_meta($data['metas']['post_id'], 'eg_use_skin', true), true); $use_skin[$data['metas']['grid_id']]['use-skin'] = $data['metas']['eg_use_skin']; $use_skin = json_encode($use_skin); update_post_meta($data['metas']['post_id'], 'eg_use_skin', $use_skin); $result = self::custom_meta_box_save($data['metas']['post_id'], $data['metas'], true); self::check_for_transient_deletion($data['metas']['post_id']); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__("Post Meta saved!", EG_TEXTDOMAIN), array()); } else { Essential_Grid::ajaxResponseError(__('Post not found!', EG_TEXTDOMAIN), false); exit; } break; case 'trigger_post_meta_visibility': if (!isset($data['post_id']) || intval($data['post_id']) == 0) { Essential_Grid::ajaxResponseError(__('No Post ID/Wrong Post ID!', EG_TEXTDOMAIN), false); exit; } if (!isset($data['grid_id']) || intval($data['grid_id']) == 0) { Essential_Grid::ajaxResponseError(__('Please save the grid first to use this feature!', EG_TEXTDOMAIN), false); exit; } $visibility = json_decode(get_post_meta($data['post_id'], 'eg_visibility', true), true); $found = false; if (!empty($visibility) && is_array($visibility)) { foreach ($visibility as $grid => $setting) { if ($grid == $data['grid_id']) { if ($setting == false) { $visibility[$grid] = true; } else { $visibility[$grid] = false; } $found = true; break; } } } if (!$found) { $visibility[$data['grid_id']] = false; } $visibility = json_encode($visibility); update_post_meta($data['post_id'], 'eg_visibility', $visibility); self::check_for_transient_deletion($data['post_id']); Essential_Grid::ajaxResponseSuccess(__("Visibility of Post for this Grid changed!", EG_TEXTDOMAIN), array()); break; case 'get_image_by_id': if (!isset($data['img_id']) || intval($data['img_id']) == 0) { $error = __('Wrong Image ID given', EG_TEXTDOMAIN); } else { $img = wp_get_attachment_image_src($data['img_id'], 'full'); if ($img !== false) { Essential_Grid::ajaxResponseSuccess('', array('url' => $img[0])); } else { $error = __('Image with given ID does not exist', EG_TEXTDOMAIN); } } break; case 'activate_purchase_code': $result = false; if (!empty($data['username']) && !empty($data['api_key']) && !empty($data['code'])) { $result = Essential_Grid_Admin::check_purchase_verification($data); } else { $error = __('The API key, the Purchase Code and the Username need to be set!', EG_TEXTDOMAIN); } if ($result === true) { Essential_Grid::ajaxResponseSuccess(__('Purchase Code Successfully Activated', EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getViewUrl("", "", 'essential-' . Essential_Grid_Admin::VIEW_START))); } else { if ($result !== false) { $error = $result; } else { $error = __('Purchase Code is invalid', EG_TEXTDOMAIN); } Essential_Grid::ajaxResponseError($error, false); exit; } break; case 'deactivate_purchase_code': $result = Essential_Grid_Admin::do_purchase_deactivation($data); if ($result === true) { Essential_Grid::ajaxResponseSuccess(__('Successfully removed validation', EG_TEXTDOMAIN), array('data' => $result, 'is_redirect' => true, 'redirect_url' => self::getViewUrl("", "", 'essential-' . Essential_Grid_Admin::VIEW_START))); } else { if ($result !== false) { $error = $result; } else { $error = __('Could not remove Validation!', EG_TEXTDOMAIN); } Essential_Grid::ajaxResponseError($error, false); exit; } break; case 'dismiss_notice': update_option('tp_eg_valid-notice', 'false'); Essential_Grid::ajaxResponseSuccess('.'); break; case 'import_default_post_data': try { require EG_PLUGIN_PATH . 'includes/assets/default-posts.php'; require EG_PLUGIN_PATH . 'includes/assets/default-grids-meta-fonts.php'; if (isset($json_tax)) { $import_tax = new PunchPost(); $import_tax->import_taxonomies($json_tax); } //insert meta, grids & punchfonts $im = new Essential_Grid_Import(); if (isset($tp_grid_meta_fonts)) { $tp_grid_meta_fonts = json_decode($tp_grid_meta_fonts, true); $grids = @$tp_grid_meta_fonts['grids']; if (!empty($grids) && is_array($grids)) { $grids_imported = $im->import_grids($grids); } $custom_metas = @$tp_grid_meta_fonts['custom-meta']; if (!empty($custom_metas) && is_array($custom_metas)) { $custom_metas_imported = $im->import_custom_meta($custom_metas); } $custom_fonts = @$tp_grid_meta_fonts['punch-fonts']; if (!empty($custom_fonts) && is_array($custom_fonts)) { $custom_fonts_imported = $im->import_punch_fonts($custom_fonts); } } if (isset($json_posts)) { $import = new PunchPort(); $import->set_tp_import_posts($json_posts); $import->import_custom_posts(); } Essential_Grid::ajaxResponseSuccess(__('Demo data successfully imported', EG_TEXTDOMAIN), array()); } catch (Exception $d) { $error = __('Something went wrong, please contact the developer', EG_TEXTDOMAIN); } break; case 'export_data': $export_grids = self::getPostVar('export-grids-id', false); $export_skins = self::getPostVar('export-skins-id', false); $export_elements = self::getPostVar('export-elements-id', false); $export_navigation_skins = self::getPostVar('export-navigation-skins-id', false); $export_global_styles = self::getPostVar('export-global-styles', false); $export_custom_meta = self::getPostVar('export-custom-meta-handle', false); $export_punch_fonts = self::getPostVar('export-punch-fonts-handle', false); header('Content-Type: text/json'); header('Content-Disposition: attachment;filename=ess_grid.json'); ob_start(); $export = array(); $ex = new Essential_Grid_Export(); //export Grids if (!empty($export_grids)) { $export['grids'] = $ex->export_grids($export_grids); } //export Skins if (!empty($export_skins)) { $export['skins'] = $ex->export_skins($export_skins); } //export Elements if (!empty($export_elements)) { $export['elements'] = $ex->export_elements($export_elements); } //export Navigation Skins if (!empty($export_navigation_skins)) { $export['navigation-skins'] = $ex->export_navigation_skins($export_navigation_skins); } //export Custom Meta if (!empty($export_custom_meta)) { $export['custom-meta'] = $ex->export_custom_meta($export_custom_meta); } //export Punch Fonts if (!empty($export_punch_fonts)) { $export['punch-fonts'] = $ex->export_punch_fonts($export_punch_fonts); } //export Global Styles if ($export_global_styles == 'on') { $export['global-css'] = $ex->export_global_styles($export_global_styles); } echo json_encode($export); $content = ob_get_contents(); ob_clean(); ob_end_clean(); echo $content; exit; break; case 'import_data': if (!isset($data['imports']) || empty($data['imports'])) { Essential_Grid::ajaxResponseError(__('No data for import selected', EG_TEXTDOMAIN), false); exit; } try { $im = new Essential_Grid_Import(); $temp_d = @$data['imports']; unset($temp_d['data-grids']); unset($temp_d['data-skins']); unset($temp_d['data-elements']); unset($temp_d['data-navigation-skins']); unset($temp_d['data-global-css']); $im->set_overwrite_data($temp_d); //set overwrite data global to class $skins = @$data['imports']['data-skins']; if (!empty($skins) && is_array($skins)) { foreach ($skins as $key => $skin) { $tskin = json_decode(stripslashes($skin), true); if (empty($tskin)) { $tskin = json_decode($skin, true); } $skins[$key] = $tskin; } if (!empty($skins)) { $skins_ids = @$data['imports']['import-skins-id']; $skins_imported = $im->import_skins($skins, $skins_ids); } } $navigation_skins = @$data['imports']['data-navigation-skins']; if (!empty($navigation_skins) && is_array($navigation_skins)) { foreach ($navigation_skins as $key => $navigation_skin) { $tnavigation_skin = json_decode(stripslashes($navigation_skin), true); if (empty($tnavigation_skin)) { $tnavigation_skin = json_decode($navigation_skin, true); } $navigation_skins[$key] = $tnavigation_skin; } if (!empty($navigation_skins)) { $navigation_skins_ids = @$data['imports']['import-navigation-skins-id']; $navigation_skins_imported = $im->import_navigation_skins(@$navigation_skins, $navigation_skins_ids); } } $grids = @$data['imports']['data-grids']; if (!empty($grids) && is_array($grids)) { foreach ($grids as $key => $grid) { $tgrid = json_decode(stripslashes($grid), true); if (empty($tgrid)) { $tgrid = json_decode($grid, true); } $grids[$key] = $tgrid; } if (!empty($grids)) { $grids_ids = @$data['imports']['import-grids-id']; $grids_imported = $im->import_grids($grids, $grids_ids); } } $elements = @$data['imports']['data-elements']; if (!empty($elements) && is_array($elements)) { foreach ($elements as $key => $element) { $telement = json_decode(stripslashes($element), true); if (empty($telement)) { $telement = json_decode($element, true); } $elements[$key] = $telement; } if (!empty($elements)) { $elements_ids = @$data['imports']['import-elements-id']; $elements_imported = $im->import_elements(@$elements, $elements_ids); } } $custom_metas = @$data['imports']['data-custom-meta']; if (!empty($custom_metas) && is_array($custom_metas)) { foreach ($custom_metas as $key => $custom_meta) { $tcustom_meta = json_decode(stripslashes($custom_meta), true); if (empty($tcustom_meta)) { $tcustom_meta = json_decode($custom_meta, true); } $custom_metas[$key] = $tcustom_meta; } if (!empty($custom_metas)) { $custom_metas_handle = @$data['imports']['import-custom-meta-handle']; $custom_metas_imported = $im->import_custom_meta($custom_metas, $custom_metas_handle); } } $custom_fonts = @$data['imports']['data-punch-fonts']; if (!empty($custom_fonts) && is_array($custom_fonts)) { foreach ($custom_fonts as $key => $custom_font) { $tcustom_font = json_decode(stripslashes($custom_font), true); if (empty($tcustom_font)) { $tcustom_font = json_decode($custom_font, true); } $custom_fonts[$key] = $tcustom_font; } if (!empty($custom_fonts)) { $custom_fonts_handle = @$data['imports']['import-punch-fonts-handle']; $custom_fonts_imported = $im->import_punch_fonts($custom_fonts, $custom_fonts_handle); } } if (@$data['imports']['import-global-styles'] == 'on') { $global_css = @$data['imports']['data-global-css']; $tglobal_css = stripslashes($global_css); if (empty($tglobal_css)) { $tglobal_css = $global_css; } $global_styles_imported = $im->import_global_styles($tglobal_css); } Essential_Grid::ajaxResponseSuccess(__('Successfully imported data', EG_TEXTDOMAIN), array('is_redirect' => true, 'redirect_url' => self::getViewUrl("", "", 'essential-' . Essential_Grid_Admin::VIEW_START))); } catch (Exception $d) { $error = __('Something went wrong, please contact the developer', EG_TEXTDOMAIN); } break; case 'delete_full_cache': $lang = array(); if (Essential_Grid_Wpml::is_wpml_exists()) { $lang = icl_get_languages(); } $grids = Essential_Grid::get_essential_grids(); if (!empty($grids)) { foreach ($grids as $grid) { if (!empty($lang)) { foreach ($lang as $code => $val) { delete_transient('ess_grid_trans_query_' . $grid->id . $val['language_code']); delete_transient('ess_grid_trans_full_grid_' . $grid->id . $val['language_code']); } } else { delete_transient('ess_grid_trans_query_' . $grid->id); delete_transient('ess_grid_trans_full_grid_' . $grid->id); } } } Essential_Grid::ajaxResponseSuccess(__('Successfully deleted all cache', EG_TEXTDOMAIN), array()); break; case "get_image_url": if (isset($data['imageid']) && intval($data['imageid']) > 0) { $img_atts = wp_get_attachment_image_src($data['imageid']); if ($img_atts !== false) { $img_src = $img_atts[0]; Essential_Grid::ajaxResponseSuccess(__("Image URL found", EG_TEXTDOMAIN), array('url' => $img_src, 'imageid' => $data['imageid'])); } } $error = __('No correct image ID given', EG_TEXTDOMAIN); break; case "toggle_grid_favorite": if (isset($data['id']) && intval($data['id']) > 0) { $return = self::toggle_favorite_by_id($data['id']); if ($return === true) { Essential_Grid::ajaxResponseSuccess(__("Favorite Set", EG_TEXTDOMAIN)); } else { $error = $return; } } else { $error = __('No ID given', EG_TEXTDOMAIN); } break; case "subscribe_to_newsletter": if (isset($data['email']) && !empty($data['email'])) { $return = ThemePunch_Newsletter::subscribe($data['email']); if ($return !== false) { if (!isset($return['status']) || $return['status'] === 'error') { $error = isset($return['message']) && !empty($return['message']) ? $return['message'] : __('Invalid Email', EG_TEXTDOMAIN); } else { Essential_Grid::ajaxResponseSuccess(__("Success! Please check your Emails to finish the subscribtion", EG_TEXTDOMAIN), $return); } } else { $error = __('Invalid Email/Could not connect to the Newsletter server', EG_TEXTDOMAIN); } } else { $error = __('No Email given', EG_TEXTDOMAIN); } break; case "unsubscribe_to_newsletter": if (isset($data['email']) && !empty($data['email'])) { $return = ThemePunch_Newsletter::unsubscribe($data['email']); if ($return !== false) { if (!isset($return['status']) || $return['status'] === 'error') { $error = isset($return['message']) && !empty($return['message']) ? $return['message'] : __('Invalid Email', EG_TEXTDOMAIN); } else { Essential_Grid::ajaxResponseSuccess(__("Success! Please check your Emails to finish the process", EG_TEXTDOMAIN), $return); } } else { $error = __('Invalid Email/Could not connect to the Newsletter server', EG_TEXTDOMAIN); } } else { $error = __('No Email given', EG_TEXTDOMAIN); } break; default: $error = true; break; } } else { $error = true; } if ($error !== false) { $showError = __("Wrong Request!", EG_TEXTDOMAIN); if ($error !== true) { $showError = __("Ajax Error: ", EG_TEXTDOMAIN) . $error; } Essential_Grid::ajaxResponseError($showError, false); } exit; } catch (Exception $e) { exit; } }
//force the js file to be included wp_enqueue_script('essential-grid-item-editor-script', plugins_url('../../assets/js/grid-editor.js', __FILE__), array('jquery'), Essential_Grid::VERSION); $base = new Essential_Grid_Base(); $item_elements = new Essential_Grid_Item_Element(); $meta = new Essential_Grid_Meta(); $meta_link = new Essential_Grid_Meta_Linking(); $fonts = new ThemePunch_Fonts(); //check if id exists and get data from database if so. $skin = false; $skin_id = false; $isCreate = $base->getGetVar('create', 'true'); $title = __('Create New Item Skin', EG_TEXTDOMAIN); $save = __('Save Item Skin', EG_TEXTDOMAIN); if (intval($isCreate) > 0) { //currently editing $skin = Essential_Grid_Item_Skin::get_essential_item_skin_by_id(intval($isCreate)); if (!empty($skin)) { $title = __('Change Item Skin', EG_TEXTDOMAIN); $save = __('Change Item Skin', EG_TEXTDOMAIN); $skin_id = intval($isCreate); } } $elements = $item_elements->getElementsForJavascript(); $style_attributes = $item_elements->get_existing_elements(true); $all_attributes = $item_elements->get_existing_elements(); $element_type = $item_elements->getElementsForDropdown(); $fonts_full = $fonts->get_all_fonts(); $meta_keys = $meta->get_all_meta_handle(); $meta_link_keys = $meta_link->get_all_link_meta_handle(); $meta_keys = array_merge($meta_keys, $meta_link_keys); $transitions_cover = $base->get_hover_animations();
/** * Add tinymce shortcode dialog * @since 1.2.0 */ public static function add_tiny_mce_shortcode_dialog() { $base = new Essential_Grid_Base(); $grid_c = new Essential_Grid(); $skins_c = new Essential_Grid_Item_Skin(); $grids = Essential_Grid::get_grids_short_vc(); ?> <div id="ess-grid-tiny-mce-dialog" tabindex="-1" action="" class="essential-dialog-wrap" title="<?php _e('Shortcode Generator', EG_TEXTDOMAIN); ?> " style="display: none; "> <script type="text/javascript"> var token = '<?php echo wp_create_nonce("Essential_Grid_actions"); ?> '; </script> <form id="ess-grid-tiny-mce-settings-form" action=""> <!-- STEP 1 --> <div id="ess-grid-tiny-dialog-step-1"> <div class="ess-top_half"> <p class="ess-quicktitle"><?php _e('Choose Predefined Grid:', EG_TEXTDOMAIN); ?> </p> <select name="ess-grid-existing-grid"> <option value="-1"><?php _e('--- Choose Grid ---', EG_TEXTDOMAIN); ?> </option> <?php if (!empty($grids)) { foreach ($grids as $title => $alias) { echo '<option value="' . $alias . '">' . $title . '</option>' . "\n"; } } ?> </select> <div style="margin-top:20px"> <a href="javascript:void(0);" class="button-primary ess-revgreen" id="eg-add-predefined-grid"><?php _e('Add Selected Grid', EG_TEXTDOMAIN); ?> </a> <a href="<?php echo Essential_Grid_Base::getViewUrl(Essential_Grid_Admin::VIEW_GRID_CREATE, 'create=true'); ?> " target="_blank" class="button-primary ess-revgreen" id="eg-create-predefined-grid"><?php _e('Create Full Grid', EG_TEXTDOMAIN); ?> </a> </div> </div> <div class="ess-bottom_half"> <p class="ess-quicktitle"><?php _e('Create a Quick Grid:', EG_TEXTDOMAIN); ?> </p> <a href="javascript:void(0);" class="" id="eg-create-custom-grid"> <div class="ess-customgridwrap"> <div class="dashicons dashicons-format-gallery ess-customgridicon"></div> <div class="ess-customonbutton"><?php _e('Add Custom', EG_TEXTDOMAIN); ?> </div> </div> </a> <a href="javascript:void(0);" class="" id="eg-edit-custom-grid"> <div class="ess-customgridwrap"> <div class="dashicons dashicons-format-gallery ess-customgridicon"></div> <div class="ess-customonbutton"><?php _e('Edit Custom', EG_TEXTDOMAIN); ?> </div> </div> </a> <a href="javascript:void(0);" class="" id="eg-create-popularpost-grid"> <div class="ess-customgridwrap"> <div class="dashicons dashicons-groups ess-customgridicon"></div> <div class="ess-customonbutton"><?php _e('Popular Post', EG_TEXTDOMAIN); ?> </div> </div> </a> <a href="javascript:void(0);" class="" id="eg-create-recentpost-grid"> <div class="ess-customgridwrap"> <div class="dashicons dashicons-calendar ess-customgridicon"></div> <div class="ess-customonbutton"><?php _e('Recent Post', EG_TEXTDOMAIN); ?> </div> </div> </a> <a href="javascript:void(0);" class="" id="eg-create-relatedpost-grid"> <div class="ess-customgridwrap"> <div class="dashicons dashicons-tickets ess-customgridicon"></div> <div class="ess-customonbutton"><?php _e('Related Post', EG_TEXTDOMAIN); ?> </div> </div> </a> </div> <div class="ess-stepnavigator"> <span class="ess-currentstep"><?php _e('STEP 1 - Choose Grid', EG_TEXTDOMAIN); ?> </span> </div> </div> <!-- STEP 2.5 --> <div id="ess-grid-tiny-dialog-step-2-5" style="display: none;"> <div id="esg-tiny-shortcode-analyze-wrap" class="ess-top_half" style="padding-top:0px;margin-top:0px;padding-bottom:30px;"> <div class="ess-quicktitle" style="margin-left:25px;"><?php _e('Edit Existing QuickGrid ShortCode', EG_TEXTDOMAIN); ?> </div> <p> <label><?php _e('Input Quickgrid Code', EG_TEXTDOMAIN); ?> </label> <input type="text" name="eg-shortcode-analyzer" value="" /> <a class="button-primary revblue" href="javascript:void(0);" id="eg-shortcode-do-analyze"><?php _e('Analyze Shortcode', EG_TEXTDOMAIN); ?> </a> </p> <p style="line-height:20px;font-size:11px;font-style:italic;color:#999;"><?php _e('You can paste your Existing Quick Grid Shortcode here for further editing. Simple copy the full Shortcode of Essential grid i.e. [ess_grid settings=....][/ess_grid] and paste it here.', EG_TEXTDOMAIN); ?> </div> <div style="width:100%;height:30px"></div> <div class="ess-stepnavigator"> <a href="javascript:void(0);" class="" id="eg-goto-step-1-5"> <div class="ess-stepbutton-left"> <div class="dashicons dashicons-arrow-left-alt2"></div> <span class="ess-currentstep"><?php _e('STEP 1 - Select Grid', EG_TEXTDOMAIN); ?> </span> </div> </a> </div> </div> <!-- STEP 2 --> <div id="ess-grid-tiny-dialog-step-2" style="display: none;"> <div id="esg-tiny-settings-wrap"> <div class="ess-top_half" style="padding:0px 0px 30px;"> <div class="ess-quicktitle" style="margin-left:25px;"><?php _e('Predefined Grid Settings', EG_TEXTDOMAIN); ?> </div> <p style=""> <label><?php _e('Choose Grid', EG_TEXTDOMAIN); ?> </label> <select name="ess-grid-tiny-existing-settings"> <option value="-1"><?php _e('--- Choose Grid to use Settings from Grid ---', EG_TEXTDOMAIN); ?> </option> <?php if (!empty($grids)) { foreach ($grids as $title => $alias) { echo '<option value="' . $alias . '">' . $title . '</option>' . "\n"; } } ?> </select> <p style="line-height:20px;font-size:11px;font-style:italic;color:#999;"><?php _e('Use the Grid Settings from one of the Existing Essential Grid. This helps to use all Complex settings of a Grid, not just the quick settings listed below.', EG_TEXTDOMAIN); ?> </p> </div> <div class="ess-bottom_half" style="padding:30px 0px 0px;"> <div class="ess-quicktitle" style="margin-left:25px;"><?php _e('Quick Grid Settings', EG_TEXTDOMAIN); ?> </div> <p class="esg-max-entries" style="display: none; background:#FFF;"> <label><?php _e('Maximum Entries', EG_TEXTDOMAIN); ?> </label> <input type="text" name="ess-grid-tiny-max-entries" value="20" /> </p> <div id="ess-grid-tiny-grid-settings-wrap"> <p> <label><?php _e('Grid Skin', EG_TEXTDOMAIN); ?> </label> <select name="ess-grid-tiny-entry-skin"> <?php $skins = Essential_Grid_Item_Skin::get_essential_item_skins('all', false); if (!empty($skins)) { foreach ($skins as $skin) { echo '<option value="' . $skin['id'] . '">' . $skin['name'] . '</option>' . "\n"; } } ?> </select> </p> <p> <label><?php _e('Layout', EG_TEXTDOMAIN); ?> </label> <select name="ess-grid-tiny-layout-sizing"> <option value="boxed"><?php _e('Boxed', EG_TEXTDOMAIN); ?> </option> <option value="fullwidth"><?php _e('Fullwidth', EG_TEXTDOMAIN); ?> </option> </select> </p> <p> <label><?php _e('Grid Layout', EG_TEXTDOMAIN); ?> </label> <select name="ess-grid-tiny-grid-layout"> <option value="even"><?php _e('Even', EG_TEXTDOMAIN); ?> </option> <option value="masonry"><?php _e('Masonry', EG_TEXTDOMAIN); ?> </option> <option value="cobbles"><?php _e('Cobbles', EG_TEXTDOMAIN); ?> </option> </select> </p> <p> <label><?php _e('Item Spacing', EG_TEXTDOMAIN); ?> </label> <input type="text" name="ess-grid-tiny-spacings" value="0" /> </p> <p> <label><?php _e('Pagination', EG_TEXTDOMAIN); ?> </label> <input type="radio" style="margin-left:0px !important;" name="ess-grid-tiny-rows-unlimited" value="on" /> <?php _e('Disable', EG_TEXTDOMAIN); ?> <input type="radio" name="ess-grid-tiny-rows-unlimited" checked="checked" value="off" /> <?php _e('Enable', EG_TEXTDOMAIN); ?> </p> <p> <label><?php _e('Columns', EG_TEXTDOMAIN); ?> </label> <input type="text" name="ess-grid-tiny-columns" value="5" /> </p> <p> <label><?php _e('Max. Visible Rows', EG_TEXTDOMAIN); ?> </label> <input type="text" name="ess-grid-tiny-rows" value="3" /> </p> <p> <label><?php _e('Start and Filter Animations', EG_TEXTDOMAIN); ?> </label> <?php $anims = Essential_Grid_Base::get_grid_animations(); ?> <select class="eg-tooltip-wrap tooltipstered" name="ess-grid-tiny-grid-animation" id="grid-animation-select"> <?php foreach ($anims as $value => $name) { echo '<option value="' . $value . '">' . $name . '</option>' . "\n"; } ?> </select> </p> <p> <label><?php _e('Choose Spinner', EG_TEXTDOMAIN); ?> </label> <select class="eg-tooltip-wrap tooltipstered" name="ess-grid-tiny-use-spinner" id="use_spinner"> <option value="-1"><?php _e('off', EG_TEXTDOMAIN); ?> </option> <option value="0" selected="selected">0</option> <option value="1">1</option> <option value="2">2</option> <option value="3">3</option> <option value="4">4</option> <option value="5">5</option> </select> </p> </div> </div> </div> <!--<a href="javascript:void(0);" class="button-primary ess-revgreen" id="eg-goto-step-3"><?php _e('Add Entries', EG_TEXTDOMAIN); ?> </a>--> <div style="width:100%;height:30px"></div> <div class="ess-stepnavigator"> <a href="javascript:void(0);" class="" id="eg-goto-step-1"> <div class="ess-stepbutton-left"> <div class="dashicons dashicons-arrow-left-alt2"></div> <span class="ess-currentstep"><?php _e('STEP 1 - Select Grid', EG_TEXTDOMAIN); ?> </span> </div> </a> <a href="javascript:void(0);" class="" id="eg-goto-step-3"> <div class="ess-stepbutton-right"> <span class="ess-currentstep"><?php _e('STEP 3 - Add Items', EG_TEXTDOMAIN); ?> </span> <div class="dashicons dashicons-arrow-right-alt2"></div> </div> </a> <a href="javascript:void(0);" class="" id="ess-grid-add-custom-shortcode-special" style="display: none;"> <div class="ess-stepbutton-right"> <span class="ess-currentstep"><?php _e('FINNISH - Generate Shortcode', EG_TEXTDOMAIN); ?> </span> <div class="dashicons dashicons-arrow-right-alt2"></div> </div> </a> </div> </div> </form> <form id="ess-grid-tiny-mce-layers-form" action=""> <!-- STEP 3 --> <div id="ess-grid-tiny-dialog-step-3" style="display: none;"> <div style="padding:30px"> <div class="ess-mediaselector"><a href="javascript:void(0);" class="eg-add-custom-element" data-type="image"><div class="dashicons dashicons-format-image"></div><?php _e('Image', EG_TEXTDOMAIN); ?> </a></div> <div class="ess-mediaselector"><a href="javascript:void(0);" class="eg-add-custom-element" data-type="html5"><div class="dashicons dashicons-editor-video"></div><?php _e('HTML5 Video', EG_TEXTDOMAIN); ?> </a></div> <div class="ess-mediaselector"><a href="javascript:void(0);" class="eg-add-custom-element" data-type="vimeo"><div class="dashicons dashicons-format-video"></div><?php _e('Vimeo', EG_TEXTDOMAIN); ?> </a></div> <div class="ess-mediaselector"><a href="javascript:void(0);" class="eg-add-custom-element" data-type="youtube"><div class="dashicons dashicons-format-video"></div><?php _e('YouTube', EG_TEXTDOMAIN); ?> </a></div> <div class="ess-mediaselector"><a href="javascript:void(0);" class="eg-add-custom-element" data-type="soundcloud"><div class="dashicons dashicons-format-audio"></div><?php _e('SoundCloud', EG_TEXTDOMAIN); ?> </a></div> <div class="ess-mediaselector collapseall"><a href="javascript:void(0);"><div class="dashicons dashicons-sort"></div><?php _e('Collapse', EG_TEXTDOMAIN); ?> </a></div> <div id="eg-custom-elements-wrap"> </div> </div> <div style="width:100%;height:30px"></div> <div class="ess-stepnavigator"> <a href="javascript:void(0);" class="" id="eg-goto-step-2"> <div class="ess-stepbutton-left"> <div class="dashicons dashicons-arrow-left-alt2"></div> <span class="ess-currentstep"><?php _e('STEP 2 - Grid Settings', EG_TEXTDOMAIN); ?> </span> </div> </a> <a href="javascript:void(0);" class="" id="ess-grid-add-custom-shortcode"> <div class="ess-stepbutton-right"> <span class="ess-currentstep"><?php _e('FINNISH - Generate Shortcode', EG_TEXTDOMAIN); ?> </span> <div class="dashicons dashicons-arrow-right-alt2"></div> </div> </a> </div> </div> </form> <div class="esg-tiny-template-wrap esg-tiny-element" style="display: none;"> <div class="ess-grid-tiny-collapse-wrapper"> <div style="width:100%;height:10px;"></div> <div class="ess-grid-tiny-custom-wrapper" > <!-- POSTER IMAGE --> <div id="ess-grid-tiny-custom-poster-wrap" class="ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-quicktitle"><?php _e('Choose Poster Image', EG_TEXTDOMAIN); ?> </div> <div class="esg-tiny-img-placeholder"><img src="" class="esg-tiny-preshow-img" style="display: none;" /></div> <a href="javascript:void(0);" class="esg-toolbutton ess-grid-select-image" data-setto="ess-grid-tiny-custom-poster[]"><div class="dashicons dashicons-plus"></div></a> <input type="hidden" name="ess-grid-tiny-custom-poster[]" data-type="image" value="" /> </div> <!-- SIMPLE IMAGE --> <div id="ess-grid-tiny-custom-image-wrap" class="ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-quicktitle"><?php _e('Choose Image', EG_TEXTDOMAIN); ?> </div> <div class="esg-tiny-img-placeholder"><img src="" class="esg-tiny-preshow-img" style="display: none;" /></div> <a href="javascript:void(0);" class="esg-toolbutton ess-grid-select-image" data-setto="ess-grid-tiny-custom-image[]"><div class="dashicons dashicons-plus"></div></a> <input type="hidden" name="ess-grid-tiny-custom-image[]" data-type="image" value="" /> </div> <!-- VIMEO ID SELECTOR --> <div id="ess-grid-tiny-custom-vimeo-wrap" class="ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-grid-tiny-elset-label"><?php _e('Vimeo ID', EG_TEXTDOMAIN); ?> </div><input type="text" name="ess-grid-tiny-custom-vimeo[]" value="" /> </div> <!-- YOUTUBE ID SELECTOR --> <div id="ess-grid-tiny-custom-youtube-wrap" class="ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-grid-tiny-elset-label"><?php _e('YouTube ID', EG_TEXTDOMAIN); ?> </div><input type="text" name="ess-grid-tiny-custom-youtube[]" value="" /> </div> <!-- SOUND CLOUD SELECTOR --> <div id="ess-grid-tiny-custom-soundcloud-wrap" class="ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-quicktitle"><?php _e('SoundCloud', EG_TEXTDOMAIN); ?> </div> <div class="ess-grid-tiny-elset-label"><?php _e('SoundCloud ID', EG_TEXTDOMAIN); ?> </div> <input type="text" name="ess-grid-tiny-custom-soundcloud[]" value="" /> </div> <!-- HTML5 SELECTORS --> <div id="ess-grid-tiny-custom-html5-wrap" class="ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-grid-tiny-elset-label"><?php _e('WEBM URL', EG_TEXTDOMAIN); ?> </div> <input type="text" name="ess-grid-tiny-custom-html5-webm[]" value="" /> <div class="ess-grid-tiny-elset-label"><?php _e('OGV URL', EG_TEXTDOMAIN); ?> </div> <input type="text" name="ess-grid-tiny-custom-html5-ogv[]" value="" /> <div class="ess-grid-tiny-elset-label"><?php _e('MP4 URL', EG_TEXTDOMAIN); ?> </div> <input type="text" name="ess-grid-tiny-custom-html5-mp4[]" value="" /> </div> <!-- VIDEO RATIO --> <div id="ess-grid-tiny-custom-ratio-wrap" class="ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-grid-tiny-elset-label"><?php _e('Video Ratio', EG_TEXTDOMAIN); ?> </div> <select name="ess-grid-tiny-custom-ratio[]"> <option value="0" selected="selected">4:3</option> <option value="1">16:9</option> </select> </div> <!-- COBBLES SETTINGS --> <div class="ess-grid-tiny-cobbles-size-wrap ess-grid-tiny-option-wrap" style="display: none;"> <div class="ess-grid-tiny-elset-label"><?php _e('Cobbles Size', EG_TEXTDOMAIN); ?> </div> <select name="ess-grid-tiny-cobbles-size[]"> <option value="1:1"><?php _e('width 1, height 1', EG_TEXTDOMAIN); ?> </option> <option value="1:2"><?php _e('width 1, height 2', EG_TEXTDOMAIN); ?> </option> <option value="1:3"><?php _e('width 1, height 3', EG_TEXTDOMAIN); ?> </option> <option value="2:1"><?php _e('width 2, height 1', EG_TEXTDOMAIN); ?> </option> <option value="2:2"><?php _e('width 2, height 2', EG_TEXTDOMAIN); ?> </option> <option value="2:3"><?php _e('width 2, height 3', EG_TEXTDOMAIN); ?> </option> <option value="3:1"><?php _e('width 3, height 1', EG_TEXTDOMAIN); ?> </option> <option value="3:2"><?php _e('width 3, height 2', EG_TEXTDOMAIN); ?> </option> <option value="3:3"><?php _e('width 3, height 3', EG_TEXTDOMAIN); ?> </option> </select> </div> <!-- CUSTOM SKIN SETTINGS --> <div class="ess-grid-tiny-use-skin-wrap ess-grid-tiny-option-wrap"> <div class="ess-grid-tiny-elset-label"><?php _e('Specific Skin', EG_TEXTDOMAIN); ?> </div> <?php $skins = Essential_Grid_Item_Skin::get_essential_item_skins('all', false); ?> <select name="ess-grid-tiny-use-skin[]"> <option value="-1"><?php _e('-- Default Skin --', EG_TEXTDOMAIN); ?> </option> <?php if (!empty($skins)) { foreach ($skins as $skin) { echo '<option value="' . $skin['id'] . '">' . $skin['name'] . '</option>' . "\n"; } } ?> </select> </div> </div> <div class="ess-grid-tiny-custom-wrapper" > <?php /*$meta = new Essential_Grid_Meta(); $custom_meta = $meta->get_all_meta(false); if(!empty($custom_meta)){ echo '<div class="ess-grid-tiny-elset-title">'; _e('Layers Content', EG_TEXTDOMAIN); echo '</div>'; foreach($custom_meta as $cmeta){ ?> <div class="ess-grid-tiny-<?php echo $cmeta['handle']; ?>-wrap ess-grid-tiny-elset-row" style="display: none;"><div class="eg-elset-label" class="eg-mb-label"><?php echo $cmeta['name']; ?>:</div> <?php switch($cmeta['type']){ case 'text': echo '<input type="text" name="ess-grid-tiny-'.$cmeta['handle'].'[]" value="" />'; break; case 'select': $el = $meta->prepare_select_by_string($cmeta['select']); echo '<select name="ess-grid-tiny-'.$cmeta['handle'].'[]">'; if(!empty($el) && is_array($el)){ echo '<option value="">'.__('---', EG_TEXTDOMAIN).'</option>'; foreach($el as $ele){ echo '<option value="'.$ele.'">'.$ele.'</option>'; } } echo '</select>'; break; case 'image': $var_src = ''; ?> <input type="hidden" value="" name="ess-grid-tiny-<?php echo $cmeta['handle']; ?>[]" id="ess-grid-tiny-<?php echo $cmeta['handle']; ?>" /> <a class="button-primary revblue eg-image-add" href="javascript:void(0);" data-setto="eg-<?php echo $cmeta['handle']; ?>"><?php _e('Choose Image', EG_TEXTDOMAIN); ?></a> <a class="button-primary revred eg-image-clear" href="javascript:void(0);" data-setto="eg-<?php echo $cmeta['handle']; ?>"><?php _e('Remove Image', EG_TEXTDOMAIN); ?></a> <div> <img id="ess-grid-tiny-<?php echo $cmeta['handle']; ?>-img" src="<?php echo $var_src; ?>" <?php echo ($var_src == '') ? 'style="max-width:200px; display: none;margin:20px 0px 0px 250px;"' : ''; ?>> </div> <?php break; } ?> </div> <?php } }else{ _e('No metas available yet. Add some through the Custom Meta menu of Essential Grid.', EG_TEXTDOMAIN); ?><div style="clear:both; height:20px"></div><?php }*/ $elements = Essential_Grid_Item_Element::getElementsForDropdown(); $p_lang = array('post' => __('Post', EG_TEXTDOMAIN), 'woocommerce' => __('WooCommerce', EG_TEXTDOMAIN)); foreach ($elements as $type => $element) { ?> <!--<div class="ess-grid-tiny-elset-title"> <?php echo $p_lang[$type]; ?> </div>--> <?php foreach ($element as $handle => $name) { echo '<div class="ess-grid-tiny-' . $handle . '-wrap ess-grid-tiny-elset-row" style="display: none;"><div class="ess-grid-tiny-elset-label" for="' . $handle . '">' . $name['name'] . ':</div><input name="ess-grid-tiny-' . $handle . '[]" value="" /></div>'; } } ?> </div> <div style="clear:both"></div> <div style="width:100%;height:30px;"></div> </div> <div class="ess-grid-tiny-custom-pictogram"><div class="dashicons dashicons-format-image"></div></div> <div class="esg-toolbutton esg-delete-item"> <a href="javascript:void(0);" class="esg-tiny-delete-entry"><div class="dashicons dashicons-trash"></div></a> </div> <div class="esg-toolbutton esg-collapsme-item"> <a href="javascript:void(0);" class="esg-tiny-collapsme-entry"><div class="dashicons dashicons-sort"></div></a> </div> <img class="esg-toolbarimg" src=""> </div> <script type="text/javascript"> <?php $skin_layers = array(); $all_skins = $skins_c->get_essential_item_skins(); if (!empty($all_skins)) { foreach ($all_skins as $cskin) { $custom_layer_elements = array(); if (isset($cskin['layers'])) { foreach ($cskin['layers'] as $layer) { if (@isset($layer['settings']['source'])) { switch ($layer['settings']['source']) { case 'post': $custom_layer_elements[@$layer['settings']['source-post']] = ''; break; case 'woocommerce': $custom_layer_elements[@$layer['settings']['source-woocommerce']] = ''; break; } } } } $skin_layers[$cskin['id']] = $custom_layer_elements; } } ?> var esg_tiny_skin_layers = jQuery.parseJSON(<?php echo $base->jsonEncodeForClientSide($skin_layers); ?> ); // KRIKI SCRIPT var esgCustomCollapser = function(bt,direction) { var cp = bt.closest('.esg-tiny-element'), cpitem = cp.find('.ess-grid-tiny-collapse-wrapper'), timg = cp.find('.esg-toolbarimg'), pimg = cp.find('.esg-tiny-preshow-img'); if ((direction=="auto" && cpitem.hasClass("collapsed")) || direction=="open") { cpitem.slideDown(200); cpitem.removeClass("collapsed"); bt.removeClass("collapsed"); timg.removeClass("collapsed"); } else { cpitem.slideUp(200); cpitem.addClass("collapsed"); bt.addClass("collapsed"); timg.addClass("collapsed"); jQuery.each(pimg,function(index,pimge) { if (jQuery(pimge).attr('src') !=undefined && jQuery(pimge).attr('src').length>0) timg.attr('src',jQuery(pimge).attr('src')); }) } } jQuery('body').on('click','.esg-toolbutton.esg-collapsme-item',function() { esgCustomCollapser(jQuery(this),"auto"); }); jQuery('.ess-mediaselector.collapseall').click(function() { var ca = jQuery(this); if (ca.hasClass("collapsed")) { jQuery('.esg-toolbutton.esg-collapsme-item').each(function() { esgCustomCollapser(jQuery(this),"open"); }) ca.removeClass("collapsed"); } else { jQuery('.esg-toolbutton.esg-collapsme-item').each(function() { esgCustomCollapser(jQuery(this),"close"); }) ca.addClass("collapsed"); } }) </script> </div> <?php }
$grid['params'] = array('layout' => 'masonry', 'navigation-skin' => 'backend-flat', 'filter-arrows' => 'single', 'navigation-padding' => '0 0 0 0', 'force_full_width' => 'off', 'rows-unlimited' => 'off', 'rows' => 3, 'columns' => array(4, 3, 3, 2, 2, 2, 1), 'columns-width' => array(1400, 1170, 1024, 960, 778, 640, 480), 'spacings' => 15, 'grid-animation' => 'fade', 'grid-animation-speed' => 800, 'grid-animation-delay' => 5, 'x-ratio' => 4, 'y-ratio' => 3); $skins_html = ''; $skins_css = ''; $filters = array(); $skins = $skins_c->get_essential_item_skins(); $demo_img = array(); for ($i = 1; $i <= 4; $i++) { $demo_img[] = 'demoimage' . $i . '.jpg'; } if (!empty($skins) && is_array($skins)) { $src = array(); foreach ($skins as $skin) { if (empty($src)) { $src = $demo_img; } $item_skin = new Essential_Grid_Item_Skin(); $item_skin->init_by_data($skin); //set filters $item_skin->set_demo_filter(); //add skin specific css $item_skin->register_skin_css(); //set demo image $img_key = array_rand($src); $item_skin->set_image($src[$img_key]); unset($src[$img_key]); $item_filter = $item_skin->get_filter_array(); $filters = array_merge($item_filter, $filters); ob_start(); $item_skin->output_item_skin('overview'); $skins_html .= ob_get_contents(); ob_clean();
/** * Output by specific ids for load more custom grid */ public function output_by_specific_ids() { $base = new Essential_Grid_Base(); $item_skin = new Essential_Grid_Item_Skin(); $item_skin->grid_id = $this->grid_id; $item_skin->set_grid_type($base->getVar($this->grid_params, 'layout', 'even')); $item_skin->set_default_image_by_id($base->getVar($this->grid_postparams, 'default-image', 0, 'i')); $m = new Essential_Grid_Meta(); $filters = array(); $order_by = explode(',', $base->getVar($this->grid_params, 'sorting-order-by', 'date')); if (!is_array($order_by)) { $order_by = array($order_by); } $item_skin->init_by_id($base->getVar($this->grid_params, 'entry-skin', 0, 'i')); $lazy_load = $base->getVar($this->grid_params, 'lazy-loading', 'off'); if ($lazy_load == 'on') { $item_skin->set_lazy_load(true); } $default_media_source_order = $base->getVar($this->grid_postparams, 'media-source-order', ''); $item_skin->set_default_media_source_order($default_media_source_order); $default_lightbox_source_order = $base->getVar($this->grid_params, 'lb-source-order', ''); $item_skin->set_default_lightbox_source_order($default_lightbox_source_order); $default_aj_source_order = $base->getVar($this->grid_params, 'aj-source-order', ''); $item_skin->set_default_ajax_source_order($default_aj_source_order); $post_media_source_type = $base->getVar($this->grid_postparams, 'image-source-type', 'full'); $default_video_poster_order = $base->getVar($this->grid_params, 'poster-source-order', ''); $item_skin->set_default_video_poster_order($default_video_poster_order); $layout = $base->getVar($this->grid_params, 'layout', 'even'); $layout_sizing = $base->getVar($this->grid_params, 'layout-sizing', 'boxed'); if ($layout_sizing !== 'fullwidth' && $layout == 'masonry') { $item_skin->set_poster_cropping(true); } $skins_html = ''; $found_filter = array(); if (!empty($this->grid_layers) && count($this->grid_layers) > 0) { foreach ($this->grid_layers as $key => $entry) { if (!in_array($key, $this->filter_by_ids)) { continue; } $post_media_source_data = $base->get_custom_media_source_data($entry, $post_media_source_type); $post_video_ratios = $m->get_custom_video_ratios($entry); $filters = array(); if (is_array($order_by) && !empty($order_by)) { //$sort = $this->prepare_sorting_array_by_post($post, $order_by); //$item_skin->set_sorting($sort); } if (!empty($entry['custom-filter'])) { $cats = explode(',', $entry['custom-filter']); if (!is_array($cats)) { $cats = (array) $cats; } foreach ($cats as $category) { $filters[sanitize_key($category)] = array('name' => $category, 'slug' => sanitize_key($category)); } } $found_filter = $found_filter + $filters; //these are the found filters, only show filter that the posts have $item_skin->set_filter($filters); $item_skin->set_media_sources($post_media_source_data); $item_skin->set_media_sources_type($post_media_source_type); $item_skin->set_video_ratios($post_video_ratios); $item_skin->set_layer_values($entry); $item_skin->set_load_more(); //switch to different skin $use_item_skin_id = $base->getVar($entry, 'use-skin', '-1'); if (intval($use_item_skin_id) === 0) { $use_item_skin_id = -1; } $item_skin->switch_item_skin($use_item_skin_id); $item_skin->register_layer_css(); $item_skin->register_skin_css(); ob_start(); $item_skin->output_item_skin(); $skins_html .= ob_get_contents(); ob_clean(); ob_end_clean(); } } else { return false; } return $skins_html; }
* Represents the view for the metabox in post / pages * * @package Essential_Grid * @author ThemePunch <*****@*****.**> * @link http://www.themepunch.com/essential/ * @copyright 2014 ThemePunch */ if (!defined('ABSPATH')) { exit; } if (!isset($post)) { return false; } //not called as it should be $base = new Essential_Grid_Base(); $item_skin = new Essential_Grid_Item_Skin(); $item_elements = new Essential_Grid_Item_Element(); $meta = new Essential_Grid_Meta(); $values = get_post_custom($post->ID); $eg_sources_html5_mp4 = isset($values['eg_sources_html5_mp4']) ? esc_attr($values['eg_sources_html5_mp4'][0]) : ""; $eg_sources_html5_ogv = isset($values['eg_sources_html5_ogv']) ? esc_attr($values['eg_sources_html5_ogv'][0]) : ""; $eg_sources_html5_webm = isset($values['eg_sources_html5_webm']) ? esc_attr($values['eg_sources_html5_webm'][0]) : ""; $eg_vimeo_ratio = isset($values['eg_vimeo_ratio']) ? esc_attr($values['eg_vimeo_ratio'][0]) : "0"; $eg_youtube_ratio = isset($values['eg_youtube_ratio']) ? esc_attr($values['eg_youtube_ratio'][0]) : "0"; $eg_wistia_ratio = isset($values['eg_wistia_ratio']) ? esc_attr($values['eg_wistia_ratio'][0]) : "0"; $eg_html5_ratio = isset($values['eg_html5_ratio']) ? esc_attr($values['eg_html5_ratio'][0]) : "0"; $eg_soundcloud_ratio = isset($values['eg_soundcloud_ratio']) ? esc_attr($values['eg_soundcloud_ratio'][0]) : "0"; $eg_sources_youtube = isset($values['eg_sources_youtube']) ? esc_attr($values['eg_sources_youtube'][0]) : ""; $eg_sources_wistia = isset($values['eg_sources_wistia']) ? esc_attr($values['eg_sources_wistia'][0]) : ""; $eg_sources_vimeo = isset($values['eg_sources_vimeo']) ? esc_attr($values['eg_sources_vimeo'][0]) : ""; $eg_sources_image = isset($values['eg_sources_image']) ? esc_attr($values['eg_sources_image'][0]) : "";
$columns_height = $base->getVar($grid['params'], 'columns-height', ''); $columns_height = $base->set_basic_colums_height($columns_height); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-0', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-1', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-2', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-3', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-4', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-5', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-6', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-7', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-8', ''); $columns_advanced[] = $base->getVar($grid['params'], 'columns-advanced-rows-9', ''); $nav_skin_choosen = $base->getVar($grid['params'], 'navigation-skin', 'minimal-light'); $navigation_skins = $nav_skin->get_essential_navigation_skins(); $navigation_skin_css = $base->jsonEncodeForClientSide($navigation_skins); $entry_skins = Essential_Grid_Item_Skin::get_essential_item_skins(); $entry_skin_choosen = $base->getVar($grid['params'], 'entry-skin', '0'); $grid_animations = $base->get_grid_animations(); $hover_animations = $base->get_hover_animations(); $grid_animation_choosen = $base->getVar($grid['params'], 'grid-animation', 'fade'); $hover_animation_choosen = $base->getVar($grid['params'], 'hover-animation', 'fade'); if (intval($isCreate) > 0) { //currently editing, so default can be empty $media_source_order = $base->getVar($grid['postparams'], 'media-source-order', ''); } else { $media_source_order = $base->getVar($grid['postparams'], 'media-source-order', array('featured-image')); } $media_source_list = $base->get_media_source_order(); $custom_elements = $base->get_custom_elements_for_javascript(); $all_image_sizes = $base->get_all_image_sizes(); $meta_keys = $meta->get_all_meta_handle();
public function import_skins($import_skins, $import_ids, $check_append = true) { if ($import_skins !== false && !empty($import_skins)) { global $wpdb; $item_skin = new Essential_Grid_Item_Skin(); $base = new Essential_Grid_Base(); $table_name = $wpdb->prefix . Essential_Grid::TABLE_ITEM_SKIN; $skins = $item_skin->get_essential_item_skins('all', false); //false = do not decode params foreach ($import_skins as $i_skin) { if (!empty($import_ids) && is_array($import_ids)) { $found = false; foreach ($import_ids as $id) { if ($i_skin['id'] == $id) { $found = true; break; } } if (!$found) { continue; } } else { break; } $exist = false; if (!empty($skins)) { foreach ($skins as $skin) { if ($skin['handle'] == $i_skin['handle']) { $i_skin['id'] = $skin['id']; //this will force an update $exist = true; break; } } } $append = true; if ($exist) { //skin exists - append or overwrite if ($check_append) { //check in data if append or overwrite $do = $base->getVar($this->overwrite_data, 'skin-overwrite-' . $i_skin['id'], 'append'); $append = $do == 'append' ? true : false; } } if ($append) { //append if ($exist) { $i_skin['handle'] = $i_skin['handle'] . '-' . date('His'); $i_skin['name'] = $i_skin['name'] . '-' . date('His'); } $response = $wpdb->insert($table_name, array('name' => $i_skin['name'], 'handle' => $i_skin['handle'], 'params' => $i_skin['params'], 'layers' => $i_skin['layers'])); } else { //overwrite $response = $wpdb->update($table_name, array('name' => $i_skin['name'], 'handle' => $i_skin['handle'], 'params' => $i_skin['params'], 'layers' => $i_skin['layers']), array('id' => $i_skin['id'])); } } } }
public function export_essential_grid() { require_once ABSPATH . 'wp-content/plugins/essential-grid/essential-grid.php'; $c_grid = new Essential_Grid(); $export_grids = array(); $grids = $c_grid->get_essential_grids(); foreach ($grids as $grid) { $export_grids[] = $grid->id; } $export_skins = array(); $item_skin = new Essential_Grid_Item_Skin(); $skins = $item_skin->get_essential_item_skins('all', false); foreach ($skins as $skin) { $export_grids[] = $skin['id']; } $export_elements = array(); $c_elements = new Essential_Grid_Item_Element(); $elements = $c_elements->get_essential_item_elements(); foreach ($elements as $element) { $export_elements[] = $element['id']; } $export_navigation_skins = array(); $c_nav_skins = new Essential_Grid_Navigation(); $nav_skins = $c_nav_skins->get_essential_navigation_skins(); foreach ($nav_skins as $nav_skin) { $export_navigation_skins[] = $nav_skin['id']; } $export_custom_meta = array(); $metas = new Essential_Grid_Meta(); $custom_metas = $metas->get_all_meta(); foreach ($custom_metas as $custom_meta) { $export_custom_meta[] = $custom_meta['handle']; } $export_punch_fonts = array(); $fonts = new ThemePunch_Fonts(); $custom_fonts = $fonts->get_all_fonts(); foreach ($custom_fonts as $custom_font) { $export_punch_fonts[] = $custom_font['handle']; } $export = array(); $ex = new Essential_Grid_Export(); //export Grids if (!empty($export_grids)) { $export['grids'] = $ex->export_grids($export_grids); } //export Skins if (!empty($export_skins)) { $export['skins'] = $ex->export_skins($export_skins); } //export Elements if (!empty($export_elements)) { $export['elements'] = $ex->export_elements($export_elements); } //export Navigation Skins if (!empty($export_navigation_skins)) { $export['navigation-skins'] = $ex->export_navigation_skins($export_navigation_skins); } //export Custom Meta if (!empty($export_custom_meta)) { $export['custom-meta'] = $ex->export_custom_meta($export_custom_meta); } //export Punch Fonts if (!empty($export_punch_fonts)) { $export['punch-fonts'] = $ex->export_punch_fonts($export_punch_fonts); } //export Global Styles $export['global-css'] = $ex->export_global_styles('on'); $this->save_as_txt_file('essential_grid.txt', json_encode($export)); }