87 lines
2.1 KiB
PHP
87 lines
2.1 KiB
PHP
<?php
|
|
/**
|
|
* Admin settings helper
|
|
*
|
|
* @link https://developer.wordpress.org/themes/basics/theme-functions/
|
|
*
|
|
* @package Astra
|
|
* @author Astra
|
|
* @copyright Copyright (c) 2020, Astra
|
|
* @link https://wpastra.com/
|
|
* @since Astra 1.0
|
|
*/
|
|
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit; // Exit if accessed directly.
|
|
}
|
|
|
|
if ( ! class_exists( 'Astra_Admin_Helper' ) ) :
|
|
|
|
/**
|
|
* Admin Helper
|
|
*/
|
|
final class Astra_Admin_Helper {
|
|
|
|
/**
|
|
* Returns an option from the database for
|
|
* the admin settings page.
|
|
*
|
|
* @param string $key The option key.
|
|
* @param boolean $network Whether to allow the network admin setting to be overridden on subsites.
|
|
* @return string Return the option value
|
|
*/
|
|
public static function get_admin_settings_option( $key, $network = false ) {
|
|
|
|
// Get the site-wide option if we're in the network admin.
|
|
if ( $network && is_multisite() ) {
|
|
$value = get_site_option( $key );
|
|
} else {
|
|
$value = get_option( $key );
|
|
}
|
|
|
|
return $value;
|
|
}
|
|
|
|
/**
|
|
* Updates an option from the admin settings page.
|
|
*
|
|
* @param string $key The option key.
|
|
* @param mixed $value The value to update.
|
|
* @param bool $network Whether to allow the network admin setting to be overridden on subsites.
|
|
* @return mixed
|
|
*/
|
|
public static function update_admin_settings_option( $key, $value, $network = false ) {
|
|
|
|
// Update the site-wide option since we're in the network admin.
|
|
if ( $network && is_multisite() ) {
|
|
update_site_option( $key, $value );
|
|
} else {
|
|
update_option( $key, $value );
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Returns an option from the database for
|
|
* the admin settings page.
|
|
*
|
|
* @param string $key The option key.
|
|
* @param bool $network Whether to allow the network admin setting to be overridden on subsites.
|
|
* @return mixed
|
|
*/
|
|
public static function delete_admin_settings_option( $key, $network = false ) {
|
|
|
|
// Get the site-wide option if we're in the network admin.
|
|
if ( $network && is_multisite() ) {
|
|
$value = delete_site_option( $key );
|
|
} else {
|
|
$value = delete_option( $key );
|
|
}
|
|
|
|
return $value;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
endif;
|