📄 Viewing: class-sns-theme-page.php

<?php
/**
 * SnS_Theme_Page
 *
 * Allows WordPress admin users the ability to edit theme CSS
 * and LESS directly in the admin via CodeMirror.
 *
 * On the `wp_enqueue_scripts` action, use `wp_enqueue_style( 'theme_style', get_stylesheet_uri() );` to add your style.css instead of inline.
 * On the `after_setup_theme` action, use `add_theme_support( 'scripts-n-styles', array( '/less/variables.less', '/less/mixins.less' ) );` but use the appropriate file locations.
 *
 */

class SnS_Theme_Page
{
	/**
	 * Constants
	 */
	const MENU_SLUG = 'sns_theme';

	static $files = array();

	/**
	 * Initializing method.
	 * @static
	 */
	static function init() {
		$hook_suffix = add_submenu_page( SnS_Admin::$parent_slug, __( 'Scripts n Styles', 'scripts-n-styles' ), __( 'Theme' ), 'unfiltered_html', self::MENU_SLUG, array( 'SnS_Form', 'page' ) );

		add_action( "load-$hook_suffix", array( __CLASS__, 'admin_load' ) );
		add_action( "load-$hook_suffix", array( 'SnS_Admin', 'help' ) );
		add_action( "load-$hook_suffix", array( 'SnS_Form', 'take_action' ), 49 );
		add_action( "admin_print_styles-$hook_suffix", array( __CLASS__, 'admin_enqueue_scripts' ) );

		// Make the page into a tab.
		if ( SnS_Admin::MENU_SLUG != SnS_Admin::$parent_slug ) {
			remove_submenu_page( SnS_Admin::$parent_slug, self::MENU_SLUG );
			add_filter( 'parent_file', array( __CLASS__, 'parent_file') );
		}
	}
	static function parent_file( $parent_file ) {
		global $plugin_page, $submenu_file;
		if ( self::MENU_SLUG == $plugin_page ) $submenu_file = SnS_Admin::MENU_SLUG;
		return $parent_file;
	}

	static function admin_enqueue_scripts() {
		$options = get_option( 'SnS_options' );
		$cm_theme = isset( $options[ 'cm_theme' ] ) ? $options[ 'cm_theme' ] : 'default';

		wp_enqueue_style( 'sns-options' );
		wp_enqueue_style( 'codemirror-theme' );

		wp_enqueue_script(  'sns-theme-page' );
		wp_localize_script( 'sns-theme-page', '_SnS_options', array( 'theme' => $cm_theme ) );
	}
	/**
	 * Settings Page
	 * Adds Admin Menu Item via WordPress' "Administration Menus" API. Also hook actions to register options via WordPress' Settings API.
	 */
	static function admin_load() {
		// added here to not effect other pages. Theme page requires JavaScript (less.js) or it doesn't make sense to save.
		add_filter( 'sns_show_submit_button', '__return_false' );

		register_setting(
			SnS_Admin::OPTION_GROUP,
			'SnS_options' );

		add_settings_section(
			'theme',
			__( 'Scripts n Styles Theme Files', 'scripts-n-styles' ),
			array( __CLASS__, 'less_fields' ),
			SnS_Admin::MENU_SLUG );
	}

	static function less_fields() {
		$files = array();
		$support_files = get_theme_support( 'scripts-n-styles' );

		if ( is_child_theme() )
			$root = get_stylesheet_directory();
		else
			$root = get_template_directory();

		foreach( $support_files[0] as $file ) {
			if ( is_file( $root . $file ) )
				$files[] = $root . $file;
		}

		$slug = get_stylesheet();
		$options = get_option( 'SnS_options' );
		// Stores data on a theme by theme basis.
		$theme =  isset( $options[ 'themes' ][ $slug ] ) ? $options[ 'themes' ][ $slug ] : array();
		$stored =  isset( $theme[ 'less' ] ) ? $theme[ 'less' ] : array(); // is an array of stored imported less file data
		$compiled = isset( $theme[ 'compiled' ] ) ? $theme[ 'compiled' ] : ''; // the complete compiled down css
		$slug = esc_attr( $slug );

		$open_theme_panels = json_decode( get_user_option( 'sns_open_theme_panels', get_current_user_id() ), true );

		?>
		<div style="overflow: hidden">
		<div id="less_area" style="width: 49%; float: left; overflow: hidden; margin-right: 2%;">
		<?php
		foreach ( $files as $file ) {
			$name = basename( $file );
			$raw = file_get_contents( $file );
			if ( isset( $stored[ $name ] ) ) {
				$source = $stored[ $name ];
				$less = isset( $source ) ? $source : '';
				$compiled = isset( $compiled ) ? $compiled : '';
			} else {
				$less = $raw;
				$compiled = '';
			}
			$name = esc_attr( $name );
			$lead_break = 0 == strpos( $less, PHP_EOL ) ? PHP_EOL : '';
			if ( isset( $open_theme_panels[ $name ] ) )
				$collapse = $open_theme_panels[ $name ] == 'yes' ? 'sns-collapsed ' : '';
			else
				$collapse = $less == $raw ? 'sns-collapsed ': '';
			?>
			<div class="sns-less-ide" style="overflow: hidden">
			<div class="widget"><div class="<?php echo $collapse; ?>inside">
				<span class="sns-collapsed-btn"></span>
				<label style="margin-bottom: 0;"><?php echo $name ?></label>
				<textarea data-file-name="<?php echo $name ?>" data-raw="<?php echo esc_attr( $raw ) ?>"
					name="SnS_options[themes][<?php echo $slug ?>][less][<?php echo $name ?>]"
					style="min-width: 250px; width:47%;"
					class="code less" rows="5" cols="40"><?php echo $lead_break . esc_textarea( $less ) ?></textarea>
				<div class="sns-ajax-wrap">
					<a class="sns-ajax-load button" href="#">Load Source File</a>
					<a class="sns-ajax-save button" href="#">Save All Changes</a>
					<span class="sns-ajax-loading"><span class="spinner" style="display: inline-block;"></span></span>
					<div class="single-status"><div class="updated settings-error below-h2"></div></div>
				</div>
			</div></div>
			</div>
			<?php
		}
		?>
		</div>
		<div id="css_area" class="sns-less-ide" style="width: 49%; float: left; overflow: hidden;">
			<div id="compile_status" style="display: none" class="updated settings-error below-h2">
				<p><span class="sns-ajax-loading"><span class="spinner" style="display: inline-block;"></span></span>
				<span class="status-text">Keystokes detected. 1 second delay, then compiling...</span></p>
			</div>
			<div class="widget"><div class="sns-collapsed inside">
				<span class="sns-collapsed-btn"></span>
				<label style="margin-bottom: 0;">Preview Window</label>
				<textarea
					name="SnS_options[themes][<?php echo $slug ?>][compiled]"
					style="min-width: 250px; width:47%;"
					class="code css" rows="5" cols="40"><?php echo esc_textarea( $compiled ) ?></textarea>
			</div></div>
			<div id="compiled_error" class="error settings-error below-h2"></div>
		</div>
		<?php
	}

	/**
	 * Settings Page
	 * Outputs Description text for the Global Section.
	 */
	static function global_section() {
		?>
		<div style="max-width: 55em;">
			<p><?php _e( 'Code entered here will be included in <em>every page (and post) of your site</em>, including the homepage and archives. The code will appear <strong>before</strong> Scripts and Styles registered individually.', 'scripts-n-styles' )?></p>
		</div>
		<?php
	}
}

🌑 DarkStealth — WP Plugin Edition

Directory: /home/httpd/html/matrixmodels.com/public_html_hacked/wp-content/plugins/scripts-n-styles/includes