function simplify_admin()
 {
     global $user_ID;
     global $pagenow;
     if (in_array($user_ID, $this->dummies_admin)) {
         add_filter('pre_site_transient_update_core', create_function('$a', "return null;"));
         add_action('admin_head', array(&$this, 'remove_menu'));
         if (in_array($pagenow, array('update.php', 'ms-users.php', 'ms-themes.php', 'ms-options.php', 'ms-upgrade-network.php', 'update-core.php', 'plugins.php', 'plugin-install.php', 'plugin-editor.php', 'theme-editor.php', 'theme-install.php'))) {
             WP_die('Cette fonction a été désactivée.');
         }
     }
 }
Example #2
0
function p_settings()
{
    if (!current_user_can('publish_posts')) {
        WP_die(__('You do not have sufficient permissions to access this page.'));
    }
    wp_enqueue_media();
    $hidden_field_name = 'submit_hidden';
    $currentLanguage = ICL_LANGUAGE_CODE;
    $currentLanguageName = strtoupper($currentLanguage);
    $qInformative = get_posts(array('post_type' => 'program', 'meta_query' => array(array('key' => 'has_registration', 'value' => 0, 'compare' => '='))));
    $programsInformative = array();
    $programsPractice = array();
    if ($qInformative) {
        foreach ($qInformative as $entry) {
            $programsInformative[$entry->ID] = $entry->post_title;
        }
    }
    $qPractice = get_posts(array('post_type' => 'program', 'meta_query' => array(array('key' => 'has_registration', 'value' => 1, 'compare' => '='))));
    if ($qPractice) {
        foreach ($qPractice as $entry) {
            $programsPractice[$entry->ID] = $entry->post_title;
        }
    }
    $fields = array('General' => array('fields' => array('students_count' => array('default' => '', 'type' => 'input', 'title' => 'Students Total Count'), 'logo_' . $currentLanguage => array('default' => '', 'type' => 'uploader', 'title' => 'Logo ' . $currentLanguageName), 'site_background_color' => array('default' => '', 'type' => 'input', 'title' => 'Site background color (enter hex or color name)'), 'site_background_image' => array('default' => '', 'type' => 'uploader', 'title' => 'Site Background Image'), 'map_coordinates' => array('default' => '33.893611,35.517994', 'type' => 'input', 'title' => 'Google Map Coordinates ex: 33.893611,35.517994'))), 'Homepage' => array('fields' => array('featured_program_informative' => array('default' => '', 'type' => 'select', 'title' => 'Select Featured Informative Program (homepage)', 'choices' => $programsInformative), 'featured_program_practice' => array('default' => '', 'type' => 'select', 'title' => 'Select Featured Practice Program (homepage)', 'choices' => $programsPractice))), 'Pages' => array('fields' => array('contact_information_' . $currentLanguage => array('default' => '', 'type' => 'textarea', 'html' => true, 'title' => 'Contact Page Information ' . $currentLanguageName))), 'Footer' => array('fields' => array('about_' . $currentLanguage => array('default' => '', 'type' => 'textarea', 'html' => true, 'title' => 'About CISH ' . $currentLanguageName), 'pobox_' . $currentLanguage => array('default' => '', 'type' => 'input', 'title' => 'PO.Box ' . $currentLanguageName), 'contact_phone_' . $currentLanguage => array('default' => '', 'type' => 'input', 'title' => 'Contact Phone ' . $currentLanguageName), 'email_address_' . $currentLanguage => array('default' => '', 'type' => 'input', 'title' => 'Email Address ' . $currentLanguageName), 'fax_' . $currentLanguage => array('default' => '', 'type' => 'input', 'title' => 'FAX ' . $currentLanguageName))), 'Social' => array('fields' => array('facebook_link' => array('default' => '', 'type' => 'input', 'title' => 'Facebook Link'), 'youtube_link' => array('default' => '', 'type' => 'input', 'title' => 'Youtube Link'), 'linkedin_link' => array('default' => '', 'type' => 'input', 'title' => 'LinkedIn Link'), 'googleplus_link' => array('default' => '', 'type' => 'input', 'title' => 'Google+ Link'), 'instagram_link' => array('default' => '', 'type' => 'input', 'title' => 'Instagram Link'), 'tumblr_link' => array('default' => '', 'type' => 'input', 'title' => 'Tumblr Link'), 'twitter_link' => array('default' => '', 'type' => 'input', 'title' => 'Twitter Link'))));
    $check_for_key = array();
    $key_prefix = 'psettings_';
    foreach ($fields as $f) {
        foreach ($f['fields'] as $fk => $fv) {
            $fk = $key_prefix . $fk;
            if (!isset($check_for_key[$fk])) {
                $check_for_key[$fk] = 1;
                ${$fk} = get_option($fk) ? get_option($fk) : $fv['default'];
            }
        }
    }
    if (isset($_POST[$hidden_field_name]) && $_POST[$hidden_field_name] == 'Y') {
        $check_for_key = array();
        foreach ($fields as $f) {
            foreach ($f['fields'] as $fk => $fv) {
                $fk = $key_prefix . $fk;
                if (!isset($check_for_key[$fk])) {
                    $check_for_key[$fk] = 1;
                    ${$fk} = isset($_POST[$fk]) && $_POST[$fk] != '' ? $_POST[$fk] : '';
                    ${$fk} = isset($fv['force_default']) && ${$fk} == '' ? $fv['default'] : ${$fk};
                    // check if html allowed
                    if (!isset($fv['html'])) {
                        ${$fk} = esc_html(${$fk});
                        update_option($fk, ${$fk});
                    } else {
                        update_option($fk, stripslashes(wp_filter_post_kses(addslashes(${$fk}))));
                    }
                }
            }
        }
        ?>
		<div class="updated"><p><strong>Settings saved</strong></p></div>
		<?php 
    }
    ?>
  
	<form method="post" action="">
		<input type="hidden" name="<?php 
    echo $hidden_field_name;
    ?>
" value="Y" />
		<h3>Edit Custom Settings</h3>
		<h5>Don't forget to save all changes when you're done!</h5>
		<input type="submit" name="Submit" class="button-primary" value="<?php 
    esc_attr_e('Save All Changes');
    ?>
" />
		<div id="psettingsTabs">
			<ul>
				<?php 
    foreach ($fields as $field_k => $field_v) {
        ?>
					<li><a href="#tabs-<?php 
        echo str_replace(' ', '-', $field_k);
        ?>
"><?php 
        echo $field_k;
        ?>
</a></li><?php 
    }
    ?>
			</ul>
			<?php 
    $check_for_key = array();
    foreach ($fields as $field_k => $field_v) {
        ?>
				<div id="tabs-<?php 
        echo str_replace(' ', '-', $field_k);
        ?>
">
					<div class="custom-table">
						<?php 
        foreach ($field_v['fields'] as $fk => $fv) {
            if (!isset($check_for_key[$fk])) {
                $fk = $key_prefix . $fk;
                $check_for_key[$fk] = 1;
                $force_default = isset($fv['force_default']) ? '* ' : '';
                echo '<div class="field-title">' . $force_default . $fv['title'] . '</div>';
                ?>
								<?php 
                switch ($fv['type']) {
                    default:
                    case 'input':
                        ?>
										<input type="text" name="<?php 
                        echo esc_attr($fk);
                        ?>
" value="<?php 
                        echo stripslashes(esc_attr(${$fk}));
                        ?>
"/>
										<?php 
                        break;
                    case 'select':
                        ?>
										<select name="<?php 
                        echo esc_attr($fk);
                        ?>
"><?php 
                        if (isset($fv['choices'])) {
                            $selected_value = ${$fk};
                            $found = 0;
                            foreach ($fv['choices'] as $c_k => $c_v) {
                                $selected = $selected_value == $c_k ? 'selected' : '';
                                if ($selected == 'selected') {
                                    $found = 1;
                                }
                                if (!$found) {
                                    $selected = isset($fv['default']) && $fv['default'] == $c_k ? 'selected' : '';
                                }
                                ?>
													<option <?php 
                                echo $selected;
                                ?>
 value="<?php 
                                echo esc_attr($c_k);
                                ?>
"><?php 
                                echo stripslashes(esc_attr($c_v));
                                ?>
</option><?php 
                            }
                        }
                        ?>
										</select><?php 
                        break;
                    case 'textarea':
                        $editor_settings = array('textarea_rows' => 5, 'media_buttons' => FALSE, 'teeny' => TRUE, 'tinymce' => TRUE, 'quicktags' => array('buttons' => 'link'));
                        wp_editor(stripcslashes(${$fk}), esc_attr($fk), $editor_settings);
                        break;
                    case 'uploader':
                        ?>
									 <div class="uploader">
											<label id="my-label-<?php 
                        echo esc_attr($fk);
                        ?>
"><?php 
                        echo stripslashes(esc_attr(${$fk})) ? '' : 'Please upload a file for this field';
                        ?>
</label>
											<?php 
                        if (stripslashes(esc_attr(${$fk})) != '') {
                            ?>
												<img class='custom-table-image image-exists' id="my-image-<?php 
                            echo esc_attr($fk);
                            ?>
" src="<?php 
                            echo stripslashes(esc_attr(${$fk}));
                            ?>
" /><?php 
                        } else {
                            ?>
												 <img class='custom-table-image' id="my-image-<?php 
                            echo esc_attr($fk);
                            ?>
" src="" /><?php 
                        }
                        ?>
											<input type="hidden" name="<?php 
                        echo esc_attr($fk);
                        ?>
" id="my-field-<?php 
                        echo esc_attr($fk);
                        ?>
" value="<?php 
                        echo stripslashes(esc_attr(${$fk}));
                        ?>
" />
											<input data-key="<?php 
                        echo esc_attr($fk);
                        ?>
" class="button custom-table-upload-button" name="custom-table-upload-button" value="Upload" />
										</div>
										<script>
									jQuery(document).ready(function(){
										jQuery('.custom-table-upload-button').click(function(){
											var myKey = jQuery(this).attr('data-key');
											wp.media.editor.send.attachment = function(props, attachment){
												jQuery('#my-field-' + myKey).val(attachment.url);
												jQuery('#my-label-' + myKey).html(attachment.url);
												jQuery('#my-image-' + myKey).attr('src',attachment.url).addClass('image-exists');
											}
											wp.media.editor.open(this);
											return false;
										});
									});
								 </script>
										<?php 
                        break;
                }
            }
        }
        ?>
					</div>
				</div><?php 
    }
    ?>
		</div><!-- psettings tabs -->
		
	</form>
	<?php 
}