'toogle_admin_menu_url_fbpatch', 'toggle'=>'toggle', 'show'=>'show', 'hide'=>'hide']; const OPTION_TOGGLE_MENU = ['_name'=>'toggle_admin_menu_option_fbpatch', 'show'=>'show', 'hide'=>'hide']; const NONCE = ['_name'=>'nonce_name', '_action'=>'action_name']; const ADMIN_POST_PATCH_CHOICE = 'add_patches'; /* * get path an url from plugin root * */ public static function root_path() { return plugin_dir_path(__DIR__); } public static function root_url() { return plugin_dir_url(__DIR__); } /* * --------------------------------------------------------------------------- * OPTIONS * these functions are used to select which patch is applied * */ private static $_patches = [ '_name'=>'fbpatch_list_of_patches', 'calculations'=>['checked'=>true, 'title'=>'calculations title', 'description'=>'calculation description'], 'hide_show' =>['checked'=>true, 'title'=>'hide/show title', 'description'=>'hide/show description'], 'modals' =>['checked'=>false, 'title'=>'modals title', 'description'=>'modals description'], 'urls' =>['checked'=>false, 'title'=>'urls title', 'description'=>'urls description'], ]; private static function set_option_patches() { /* * get the list of patches in option * create option if needed * */ $raw_patches_option = get_option(self::$_patches['_name']); if (false === $raw_patches_option) { add_option(self::$_patches['_name']); } $patches_option = unserialize($raw_patches_option); if (empty($patches_option)) { $patches_option = array(); } /* * if the option miss patches, add them * */ foreach (self::$_patches as $patch => $data) { if ($patch === '_name') { continue; } if (isset($patches_option[$patch])) { continue; } $patches_option[$patch] = $data; } /* * if the option has additional patches, delete them * */ foreach ($patches_option as $patch => $data) { if (isset(self::$_patches[$patch])) { continue; } unset($patches_option[$patch]); } /* * change the option list with the update patches * */ ksort($patches_option); $serialize_patches_option = serialize($patches_option); update_option(self::$_patches['_name'], $serialize_patches_option); } public static function get_patches() { self::set_option_patches(); $patches = get_option(self::$_patches['_name']); return unserialize($patches); } public static function set_patches($patches_on) { /* * loop through the option list and update occording to the received list * */ $raw_patches = get_option(self::$_patches['_name']); $patches_option = unserialize($raw_patches); foreach($patches_option as $patch => $data) { if (in_array($patch, $patches_on)) { $patches_option[$patch]['checked'] = true; } else { $patches_option[$patch]['checked'] = false; } } /* * change the option list with the update patches * */ ksort($patches_option); $serialize_patches_option = serialize($patches_option); update_option(self::$_patches['_name'], $serialize_patches_option); } /* * this function will include the files of the different patches if they are set in the options * */ public static function init_hook() { $patches = Fbpatch::get_patches(); foreach($patches as $patch => $data) { if ($data['checked'] === true) { include_once(self::root_path() . '/php/patches/'.$patch.'.php'); } } } /* * * OPTIONS END * --------------------------------------------------------------------------- */ /* * --------------------------------------------------------------------------- * HIDE SHOW * to hide the chosen elements of the form without deleting the data in acf fields * */ private static $_identification_fields = array("post_title", "ID", "_ajax_linking_nonce"); private static $_post_array_begin = array(); private static $_post_identification = array(); private static $_has_post_to_overwrite = false; private static $_was_inserted_once = false; public static function set_post_array($array) { self::$_post_array_begin = $array; self::$_post_identification = array(); self::$_has_post_to_overwrite = true; self::$_was_inserted_once = false; } public static function set_post_identification($array) { error_log("-in set_post_identification"); foreach(self::$_identification_fields as $field) { if (!isset($array[$field])) { continue; } self::$_post_identification[$field] = $array[$field]; } error_log("_post_identification: " . json_encode(self::$_post_identification)); } /* * check if should insert post : * only prevent insert if the post was already inserted with divi_form_builder hook * so we must let the post be inserted a first time, then prevent it * 1. checks if there is a post to overwrite * 2. checks if it has the same identifications than the form_builder post * */ public static function should_prevent_insert($array) { error_log("-in should_prevent_insert"); $is_same = false; if (self::$_has_post_to_overwrite === false) { error_log("_has_post_to_overwrite === false"); self::$_post_identification = array(); self::$_post_array_begin = array();; return false; } /* * check if the post identifications matches the post to overwrite * */ foreach(self::$_post_identification as $key => $value) { if (!isset($array[$key])) { error_log("!isset array[key]"); return false; } // some identifications are number, but might be in string format, hence '!=' instead of '!==' if ($array[$key] != $value) { error_log("array[key] != value"); return false; } } /* * the post identify to the post to overwrite * so we should insert it a first time * then prevent it to be inserted a second time * */ if (self::$_was_inserted_once === false) { error_log("_was_inserted_once === true"); self::$_was_inserted_once = true; return false; } self::$_post_array_begin = array();; self::$_post_identification = array(); self::$_has_post_to_overwrite = false; self::$_was_inserted_once = false; return true; } /* "post_title":"test_hugo", "ID":41586, "_ajax_linking_nonce":"9e6b4bfea2", */ /* * * HIDE SHOW * --------------------------------------------------------------------------- */ } ?>